2013-09-16 20:29:13 +00:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2013 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.
|
|
|
|
|
*/
|
|
|
|
|
|
2018-10-15 11:55:13 +02:00
|
|
|
#include "api/test/mock_video_decoder.h"
|
2017-09-15 06:47:31 +02:00
|
|
|
#include "modules/video_coding/include/video_coding.h"
|
|
|
|
|
#include "modules/video_coding/timing.h"
|
|
|
|
|
#include "modules/video_coding/video_coding_impl.h"
|
|
|
|
|
#include "system_wrappers/include/clock.h"
|
|
|
|
|
#include "test/gtest.h"
|
|
|
|
|
#include "test/video_codec_settings.h"
|
2013-09-16 20:29:13 +00:00
|
|
|
|
|
|
|
|
using ::testing::_;
|
2017-03-14 04:16:20 -07:00
|
|
|
using ::testing::AnyNumber;
|
2013-09-16 20:29:13 +00:00
|
|
|
using ::testing::NiceMock;
|
|
|
|
|
|
|
|
|
|
namespace webrtc {
|
|
|
|
|
namespace vcm {
|
|
|
|
|
namespace {
|
|
|
|
|
|
2020-02-04 10:46:37 +01:00
|
|
|
class MockPacketRequestCallback : public VCMPacketRequestCallback {
|
|
|
|
|
public:
|
|
|
|
|
MOCK_METHOD2(ResendPackets,
|
|
|
|
|
int32_t(const uint16_t* sequenceNumbers, uint16_t length));
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class MockVCMReceiveCallback : public VCMReceiveCallback {
|
|
|
|
|
public:
|
|
|
|
|
MockVCMReceiveCallback() {}
|
|
|
|
|
virtual ~MockVCMReceiveCallback() {}
|
|
|
|
|
|
|
|
|
|
MOCK_METHOD4(
|
|
|
|
|
FrameToRender,
|
|
|
|
|
int32_t(VideoFrame&, absl::optional<uint8_t>, int32_t, VideoContentType));
|
|
|
|
|
MOCK_METHOD1(OnIncomingPayloadType, void(int));
|
|
|
|
|
MOCK_METHOD1(OnDecoderImplementationName, void(const char*));
|
|
|
|
|
};
|
|
|
|
|
|
2013-09-16 20:29:13 +00:00
|
|
|
class TestVideoReceiver : public ::testing::Test {
|
|
|
|
|
protected:
|
|
|
|
|
static const int kUnusedPayloadType = 10;
|
2019-01-09 14:03:59 +01:00
|
|
|
static const uint16_t kMaxWaitTimeMs = 100;
|
2013-09-16 20:29:13 +00:00
|
|
|
|
2019-01-09 14:03:59 +01:00
|
|
|
TestVideoReceiver()
|
|
|
|
|
: clock_(0), timing_(&clock_), receiver_(&clock_, &timing_) {}
|
2013-09-16 20:29:13 +00:00
|
|
|
|
|
|
|
|
virtual void SetUp() {
|
2019-01-09 14:03:59 +01:00
|
|
|
// Register decoder.
|
|
|
|
|
receiver_.RegisterExternalDecoder(&decoder_, kUnusedPayloadType);
|
|
|
|
|
webrtc::test::CodecSettings(kVideoCodecVP8, &settings_);
|
|
|
|
|
settings_.plType = kUnusedPayloadType;
|
|
|
|
|
EXPECT_EQ(0, receiver_.RegisterReceiveCodec(&settings_, 1, true));
|
|
|
|
|
|
|
|
|
|
// Set protection mode.
|
2013-09-16 20:29:13 +00:00
|
|
|
const size_t kMaxNackListSize = 250;
|
|
|
|
|
const int kMaxPacketAgeToNack = 450;
|
2019-01-09 14:03:59 +01:00
|
|
|
receiver_.SetNackSettings(kMaxNackListSize, kMaxPacketAgeToNack, 0);
|
|
|
|
|
EXPECT_EQ(
|
|
|
|
|
0, receiver_.RegisterPacketRequestCallback(&packet_request_callback_));
|
2017-03-14 04:16:20 -07:00
|
|
|
|
|
|
|
|
// Since we call Decode, we need to provide a valid receive callback.
|
|
|
|
|
// However, for the purposes of these tests, we ignore the callbacks.
|
|
|
|
|
EXPECT_CALL(receive_callback_, OnIncomingPayloadType(_)).Times(AnyNumber());
|
|
|
|
|
EXPECT_CALL(receive_callback_, OnDecoderImplementationName(_))
|
|
|
|
|
.Times(AnyNumber());
|
2019-01-09 14:03:59 +01:00
|
|
|
receiver_.RegisterReceiveCallback(&receive_callback_);
|
|
|
|
|
}
|
|
|
|
|
|
2019-04-25 10:02:52 +02:00
|
|
|
RTPHeader GetDefaultRTPHeader() const {
|
|
|
|
|
RTPHeader header;
|
|
|
|
|
header.markerBit = false;
|
|
|
|
|
header.payloadType = kUnusedPayloadType;
|
|
|
|
|
header.ssrc = 1;
|
|
|
|
|
header.headerLength = 12;
|
2019-01-09 14:03:59 +01:00
|
|
|
return header;
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
|
2019-04-25 10:02:52 +02:00
|
|
|
RTPVideoHeader GetDefaultVp8Header() const {
|
|
|
|
|
RTPVideoHeader video_header = {};
|
|
|
|
|
video_header.frame_type = VideoFrameType::kEmptyFrame;
|
|
|
|
|
video_header.codec = kVideoCodecVP8;
|
|
|
|
|
return video_header;
|
|
|
|
|
}
|
|
|
|
|
|
2013-09-16 20:29:13 +00:00
|
|
|
void InsertAndVerifyPaddingFrame(const uint8_t* payload,
|
2019-04-25 10:02:52 +02:00
|
|
|
RTPHeader* header,
|
|
|
|
|
const RTPVideoHeader& video_header) {
|
2013-09-16 20:29:13 +00:00
|
|
|
for (int j = 0; j < 5; ++j) {
|
|
|
|
|
// Padding only packets are passed to the VCM with payload size 0.
|
2019-04-25 10:02:52 +02:00
|
|
|
EXPECT_EQ(0, receiver_.IncomingPacket(payload, 0, *header, video_header));
|
|
|
|
|
++header->sequenceNumber;
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
2019-01-09 14:03:59 +01:00
|
|
|
receiver_.Process();
|
2019-03-25 09:11:40 +01:00
|
|
|
EXPECT_CALL(decoder_, Decode(_, _, _)).Times(0);
|
2019-01-09 14:03:59 +01:00
|
|
|
EXPECT_EQ(VCM_FRAME_NOT_READY, receiver_.Decode(kMaxWaitTimeMs));
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void InsertAndVerifyDecodableFrame(const uint8_t* payload,
|
Use size_t more consistently for packet/payload lengths.
See design doc at https://docs.google.com/a/chromium.org/document/d/1I6nmE9D_BmCY-IoV6MDPY2V6WYpEI-dg2apWXTfZyUI/edit?usp=sharing for more information.
This CL was reviewed and approved in pieces in the following CLs:
https://webrtc-codereview.appspot.com/24209004/
https://webrtc-codereview.appspot.com/24229004/
https://webrtc-codereview.appspot.com/24259004/
https://webrtc-codereview.appspot.com/25109004/
https://webrtc-codereview.appspot.com/26099004/
https://webrtc-codereview.appspot.com/27069004/
https://webrtc-codereview.appspot.com/27969004/
https://webrtc-codereview.appspot.com/27989004/
https://webrtc-codereview.appspot.com/29009004/
https://webrtc-codereview.appspot.com/30929004/
https://webrtc-codereview.appspot.com/30939004/
https://webrtc-codereview.appspot.com/31999004/
Committing as TBR to the original reviewers.
BUG=chromium:81439
TEST=none
TBR=pthatcher,henrik.lundin,tina.legrand,stefan,tkchin,glaznev,kjellander,perkj,mflodman,henrika,asapersson,niklas.enbom
Review URL: https://webrtc-codereview.appspot.com/23129004
git-svn-id: http://webrtc.googlecode.com/svn/trunk@7726 4adac7df-926f-26a2-2b94-8c16560cd09d
2014-11-20 22:28:14 +00:00
|
|
|
size_t length,
|
2019-04-25 10:02:52 +02:00
|
|
|
RTPHeader* header,
|
|
|
|
|
const RTPVideoHeader& video_header) {
|
|
|
|
|
EXPECT_EQ(0,
|
|
|
|
|
receiver_.IncomingPacket(payload, length, *header, video_header));
|
|
|
|
|
++header->sequenceNumber;
|
2013-09-16 20:29:13 +00:00
|
|
|
EXPECT_CALL(packet_request_callback_, ResendPackets(_, _)).Times(0);
|
2019-01-09 14:03:59 +01:00
|
|
|
|
|
|
|
|
receiver_.Process();
|
2019-03-25 09:11:40 +01:00
|
|
|
EXPECT_CALL(decoder_, Decode(_, _, _)).Times(1);
|
2019-01-09 14:03:59 +01:00
|
|
|
EXPECT_EQ(0, receiver_.Decode(kMaxWaitTimeMs));
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SimulatedClock clock_;
|
|
|
|
|
VideoCodec settings_;
|
|
|
|
|
NiceMock<MockVideoDecoder> decoder_;
|
|
|
|
|
NiceMock<MockPacketRequestCallback> packet_request_callback_;
|
2019-01-09 14:03:59 +01:00
|
|
|
VCMTiming timing_;
|
2017-03-14 04:16:20 -07:00
|
|
|
MockVCMReceiveCallback receive_callback_;
|
2019-01-09 14:03:59 +01:00
|
|
|
VideoReceiver receiver_;
|
2013-09-16 20:29:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
TEST_F(TestVideoReceiver, PaddingOnlyFrames) {
|
Use size_t more consistently for packet/payload lengths.
See design doc at https://docs.google.com/a/chromium.org/document/d/1I6nmE9D_BmCY-IoV6MDPY2V6WYpEI-dg2apWXTfZyUI/edit?usp=sharing for more information.
This CL was reviewed and approved in pieces in the following CLs:
https://webrtc-codereview.appspot.com/24209004/
https://webrtc-codereview.appspot.com/24229004/
https://webrtc-codereview.appspot.com/24259004/
https://webrtc-codereview.appspot.com/25109004/
https://webrtc-codereview.appspot.com/26099004/
https://webrtc-codereview.appspot.com/27069004/
https://webrtc-codereview.appspot.com/27969004/
https://webrtc-codereview.appspot.com/27989004/
https://webrtc-codereview.appspot.com/29009004/
https://webrtc-codereview.appspot.com/30929004/
https://webrtc-codereview.appspot.com/30939004/
https://webrtc-codereview.appspot.com/31999004/
Committing as TBR to the original reviewers.
BUG=chromium:81439
TEST=none
TBR=pthatcher,henrik.lundin,tina.legrand,stefan,tkchin,glaznev,kjellander,perkj,mflodman,henrika,asapersson,niklas.enbom
Review URL: https://webrtc-codereview.appspot.com/23129004
git-svn-id: http://webrtc.googlecode.com/svn/trunk@7726 4adac7df-926f-26a2-2b94-8c16560cd09d
2014-11-20 22:28:14 +00:00
|
|
|
const size_t kPaddingSize = 220;
|
2019-01-09 14:03:59 +01:00
|
|
|
const uint8_t kPayload[kPaddingSize] = {0};
|
2019-04-25 10:02:52 +02:00
|
|
|
RTPHeader header = GetDefaultRTPHeader();
|
|
|
|
|
RTPVideoHeader video_header = GetDefaultVp8Header();
|
|
|
|
|
header.paddingLength = kPaddingSize;
|
2013-09-16 20:29:13 +00:00
|
|
|
for (int i = 0; i < 10; ++i) {
|
|
|
|
|
EXPECT_CALL(packet_request_callback_, ResendPackets(_, _)).Times(0);
|
2019-04-25 10:02:52 +02:00
|
|
|
InsertAndVerifyPaddingFrame(kPayload, &header, video_header);
|
2013-09-16 20:29:13 +00:00
|
|
|
clock_.AdvanceTimeMilliseconds(33);
|
2019-04-25 10:02:52 +02:00
|
|
|
header.timestamp += 3000;
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(TestVideoReceiver, PaddingOnlyFramesWithLosses) {
|
Use size_t more consistently for packet/payload lengths.
See design doc at https://docs.google.com/a/chromium.org/document/d/1I6nmE9D_BmCY-IoV6MDPY2V6WYpEI-dg2apWXTfZyUI/edit?usp=sharing for more information.
This CL was reviewed and approved in pieces in the following CLs:
https://webrtc-codereview.appspot.com/24209004/
https://webrtc-codereview.appspot.com/24229004/
https://webrtc-codereview.appspot.com/24259004/
https://webrtc-codereview.appspot.com/25109004/
https://webrtc-codereview.appspot.com/26099004/
https://webrtc-codereview.appspot.com/27069004/
https://webrtc-codereview.appspot.com/27969004/
https://webrtc-codereview.appspot.com/27989004/
https://webrtc-codereview.appspot.com/29009004/
https://webrtc-codereview.appspot.com/30929004/
https://webrtc-codereview.appspot.com/30939004/
https://webrtc-codereview.appspot.com/31999004/
Committing as TBR to the original reviewers.
BUG=chromium:81439
TEST=none
TBR=pthatcher,henrik.lundin,tina.legrand,stefan,tkchin,glaznev,kjellander,perkj,mflodman,henrika,asapersson,niklas.enbom
Review URL: https://webrtc-codereview.appspot.com/23129004
git-svn-id: http://webrtc.googlecode.com/svn/trunk@7726 4adac7df-926f-26a2-2b94-8c16560cd09d
2014-11-20 22:28:14 +00:00
|
|
|
const size_t kFrameSize = 1200;
|
|
|
|
|
const size_t kPaddingSize = 220;
|
2019-01-09 14:03:59 +01:00
|
|
|
const uint8_t kPayload[kFrameSize] = {0};
|
2019-04-25 10:02:52 +02:00
|
|
|
RTPHeader header = GetDefaultRTPHeader();
|
|
|
|
|
RTPVideoHeader video_header = GetDefaultVp8Header();
|
|
|
|
|
header.paddingLength = kPaddingSize;
|
|
|
|
|
video_header.video_type_header.emplace<RTPVideoHeaderVP8>();
|
2019-01-09 14:03:59 +01:00
|
|
|
|
2013-09-16 20:29:13 +00:00
|
|
|
// Insert one video frame to get one frame decoded.
|
2019-04-25 10:02:52 +02:00
|
|
|
video_header.frame_type = VideoFrameType::kVideoFrameKey;
|
|
|
|
|
video_header.is_first_packet_in_frame = true;
|
|
|
|
|
header.markerBit = true;
|
|
|
|
|
InsertAndVerifyDecodableFrame(kPayload, kFrameSize, &header, video_header);
|
2019-01-09 14:03:59 +01:00
|
|
|
|
2013-09-16 20:29:13 +00:00
|
|
|
clock_.AdvanceTimeMilliseconds(33);
|
2019-04-25 10:02:52 +02:00
|
|
|
header.timestamp += 3000;
|
|
|
|
|
video_header.frame_type = VideoFrameType::kEmptyFrame;
|
|
|
|
|
video_header.is_first_packet_in_frame = false;
|
|
|
|
|
header.markerBit = false;
|
2013-09-16 20:29:13 +00:00
|
|
|
// Insert padding frames.
|
|
|
|
|
for (int i = 0; i < 10; ++i) {
|
|
|
|
|
// Lose one packet from the 6th frame.
|
|
|
|
|
if (i == 5) {
|
2019-04-25 10:02:52 +02:00
|
|
|
++header.sequenceNumber;
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
// Lose the 4th frame.
|
|
|
|
|
if (i == 3) {
|
2019-04-25 10:02:52 +02:00
|
|
|
header.sequenceNumber += 5;
|
2013-09-16 20:29:13 +00:00
|
|
|
} else {
|
|
|
|
|
if (i > 3 && i < 5) {
|
|
|
|
|
EXPECT_CALL(packet_request_callback_, ResendPackets(_, 5)).Times(1);
|
|
|
|
|
} else if (i >= 5) {
|
|
|
|
|
EXPECT_CALL(packet_request_callback_, ResendPackets(_, 6)).Times(1);
|
|
|
|
|
} else {
|
|
|
|
|
EXPECT_CALL(packet_request_callback_, ResendPackets(_, _)).Times(0);
|
|
|
|
|
}
|
2019-04-25 10:02:52 +02:00
|
|
|
InsertAndVerifyPaddingFrame(kPayload, &header, video_header);
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
clock_.AdvanceTimeMilliseconds(33);
|
2019-04-25 10:02:52 +02:00
|
|
|
header.timestamp += 3000;
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(TestVideoReceiver, PaddingOnlyAndVideo) {
|
Use size_t more consistently for packet/payload lengths.
See design doc at https://docs.google.com/a/chromium.org/document/d/1I6nmE9D_BmCY-IoV6MDPY2V6WYpEI-dg2apWXTfZyUI/edit?usp=sharing for more information.
This CL was reviewed and approved in pieces in the following CLs:
https://webrtc-codereview.appspot.com/24209004/
https://webrtc-codereview.appspot.com/24229004/
https://webrtc-codereview.appspot.com/24259004/
https://webrtc-codereview.appspot.com/25109004/
https://webrtc-codereview.appspot.com/26099004/
https://webrtc-codereview.appspot.com/27069004/
https://webrtc-codereview.appspot.com/27969004/
https://webrtc-codereview.appspot.com/27989004/
https://webrtc-codereview.appspot.com/29009004/
https://webrtc-codereview.appspot.com/30929004/
https://webrtc-codereview.appspot.com/30939004/
https://webrtc-codereview.appspot.com/31999004/
Committing as TBR to the original reviewers.
BUG=chromium:81439
TEST=none
TBR=pthatcher,henrik.lundin,tina.legrand,stefan,tkchin,glaznev,kjellander,perkj,mflodman,henrika,asapersson,niklas.enbom
Review URL: https://webrtc-codereview.appspot.com/23129004
git-svn-id: http://webrtc.googlecode.com/svn/trunk@7726 4adac7df-926f-26a2-2b94-8c16560cd09d
2014-11-20 22:28:14 +00:00
|
|
|
const size_t kFrameSize = 1200;
|
|
|
|
|
const size_t kPaddingSize = 220;
|
2019-01-09 14:03:59 +01:00
|
|
|
const uint8_t kPayload[kFrameSize] = {0};
|
2019-04-25 10:02:52 +02:00
|
|
|
RTPHeader header = GetDefaultRTPHeader();
|
|
|
|
|
RTPVideoHeader video_header = GetDefaultVp8Header();
|
|
|
|
|
video_header.is_first_packet_in_frame = false;
|
|
|
|
|
header.paddingLength = kPaddingSize;
|
Reland "Remove RTPVideoHeader::vp8() accessors."
This reverts commit 1811c04f22a26da3ed2832373a5c92a9786420c3.
Reason for revert: Downstream projects fixed.
Original change's description:
> Revert "Remove RTPVideoHeader::vp8() accessors."
>
> This reverts commit af7afc66427b0e9109e7d492f2805d63d239b914.
>
> Reason for revert: Break downstream projects.
>
> Original change's description:
> > Remove RTPVideoHeader::vp8() accessors.
> >
> > Bug: none
> > Change-Id: Ia7d65148fb36a8f26647bee8a876ce7217ff8a68
> > Reviewed-on: https://webrtc-review.googlesource.com/93321
> > Reviewed-by: Niels Moller <nisse@webrtc.org>
> > Reviewed-by: Stefan Holmer <stefan@webrtc.org>
> > Reviewed-by: Danil Chapovalov <danilchap@webrtc.org>
> > Commit-Queue: Philip Eliasson <philipel@webrtc.org>
> > Cr-Commit-Position: refs/heads/master@{#24626}
>
> TBR=danilchap@webrtc.org,nisse@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,philipel@webrtc.org,holmer@google.com
>
> Change-Id: I3f7f19c0ea810c0fd988c59e6556bbea9b756b33
> No-Presubmit: true
> No-Tree-Checks: true
> No-Try: true
> Bug: none
> Reviewed-on: https://webrtc-review.googlesource.com/98864
> Reviewed-by: Philip Eliasson <philipel@webrtc.org>
> Commit-Queue: Philip Eliasson <philipel@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#24628}
TBR=danilchap@webrtc.org,nisse@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,philipel@webrtc.org,holmer@google.com
Change-Id: I9246f36e638108ae4fc46c1ae4559c8205d50fc1
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: none
Reviewed-on: https://webrtc-review.googlesource.com/98841
Reviewed-by: Philip Eliasson <philipel@webrtc.org>
Commit-Queue: Philip Eliasson <philipel@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#24629}
2018-09-07 13:03:55 +00:00
|
|
|
auto& vp8_header =
|
2019-04-25 10:02:52 +02:00
|
|
|
video_header.video_type_header.emplace<RTPVideoHeaderVP8>();
|
Reland "Remove RTPVideoHeader::vp8() accessors."
This reverts commit 1811c04f22a26da3ed2832373a5c92a9786420c3.
Reason for revert: Downstream projects fixed.
Original change's description:
> Revert "Remove RTPVideoHeader::vp8() accessors."
>
> This reverts commit af7afc66427b0e9109e7d492f2805d63d239b914.
>
> Reason for revert: Break downstream projects.
>
> Original change's description:
> > Remove RTPVideoHeader::vp8() accessors.
> >
> > Bug: none
> > Change-Id: Ia7d65148fb36a8f26647bee8a876ce7217ff8a68
> > Reviewed-on: https://webrtc-review.googlesource.com/93321
> > Reviewed-by: Niels Moller <nisse@webrtc.org>
> > Reviewed-by: Stefan Holmer <stefan@webrtc.org>
> > Reviewed-by: Danil Chapovalov <danilchap@webrtc.org>
> > Commit-Queue: Philip Eliasson <philipel@webrtc.org>
> > Cr-Commit-Position: refs/heads/master@{#24626}
>
> TBR=danilchap@webrtc.org,nisse@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,philipel@webrtc.org,holmer@google.com
>
> Change-Id: I3f7f19c0ea810c0fd988c59e6556bbea9b756b33
> No-Presubmit: true
> No-Tree-Checks: true
> No-Try: true
> Bug: none
> Reviewed-on: https://webrtc-review.googlesource.com/98864
> Reviewed-by: Philip Eliasson <philipel@webrtc.org>
> Commit-Queue: Philip Eliasson <philipel@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#24628}
TBR=danilchap@webrtc.org,nisse@webrtc.org,sprang@webrtc.org,stefan@webrtc.org,philipel@webrtc.org,holmer@google.com
Change-Id: I9246f36e638108ae4fc46c1ae4559c8205d50fc1
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: none
Reviewed-on: https://webrtc-review.googlesource.com/98841
Reviewed-by: Philip Eliasson <philipel@webrtc.org>
Commit-Queue: Philip Eliasson <philipel@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#24629}
2018-09-07 13:03:55 +00:00
|
|
|
vp8_header.pictureId = -1;
|
|
|
|
|
vp8_header.tl0PicIdx = -1;
|
2019-01-09 14:03:59 +01:00
|
|
|
|
2013-09-16 20:29:13 +00:00
|
|
|
for (int i = 0; i < 3; ++i) {
|
|
|
|
|
// Insert 2 video frames.
|
|
|
|
|
for (int j = 0; j < 2; ++j) {
|
|
|
|
|
if (i == 0 && j == 0) // First frame should be a key frame.
|
2019-04-25 10:02:52 +02:00
|
|
|
video_header.frame_type = VideoFrameType::kVideoFrameKey;
|
2013-09-16 20:29:13 +00:00
|
|
|
else
|
2019-04-25 10:02:52 +02:00
|
|
|
video_header.frame_type = VideoFrameType::kVideoFrameDelta;
|
|
|
|
|
video_header.is_first_packet_in_frame = true;
|
|
|
|
|
header.markerBit = true;
|
|
|
|
|
InsertAndVerifyDecodableFrame(kPayload, kFrameSize, &header,
|
|
|
|
|
video_header);
|
2013-09-16 20:29:13 +00:00
|
|
|
clock_.AdvanceTimeMilliseconds(33);
|
2019-04-25 10:02:52 +02:00
|
|
|
header.timestamp += 3000;
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Insert 2 padding only frames.
|
2019-04-25 10:02:52 +02:00
|
|
|
video_header.frame_type = VideoFrameType::kEmptyFrame;
|
|
|
|
|
video_header.is_first_packet_in_frame = false;
|
|
|
|
|
header.markerBit = false;
|
2013-09-16 20:29:13 +00:00
|
|
|
for (int j = 0; j < 2; ++j) {
|
2019-01-09 14:03:59 +01:00
|
|
|
// InsertAndVerifyPaddingFrame(kPayload, &header);
|
2013-09-16 20:29:13 +00:00
|
|
|
clock_.AdvanceTimeMilliseconds(33);
|
2019-04-25 10:02:52 +02:00
|
|
|
header.timestamp += 3000;
|
2013-09-16 20:29:13 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
} // namespace vcm
|
|
|
|
|
} // namespace webrtc
|