blob: d45186363b4e83170f8441c867445e9f69c5b0fc [file] [log] [blame]
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001/*
kjellanderb24317b2016-02-10 07:54:43 -08002 * Copyright 2012 The WebRTC project authors. All Rights Reserved.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003 *
kjellanderb24317b2016-02-10 07:54:43 -08004 * 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.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00009 */
10
11#include <string>
12
wu@webrtc.org967bfff2013-09-19 05:49:50 +000013#include "talk/session/media/channelmanager.h"
Henrik Kjellander15583c12016-02-10 10:53:12 +010014#include "webrtc/api/remotevideocapturer.h"
15#include "webrtc/api/test/fakevideotrackrenderer.h"
16#include "webrtc/api/videosource.h"
17#include "webrtc/api/videotrack.h"
buildbot@webrtc.orga09a9992014-08-13 17:26:08 +000018#include "webrtc/base/gunit.h"
19#include "webrtc/base/scoped_ptr.h"
kjellandera96e2d72016-02-04 23:52:28 -080020#include "webrtc/media/base/fakemediaengine.h"
21#include "webrtc/media/webrtc/webrtcvideoframe.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000022
23using webrtc::FakeVideoTrackRenderer;
wu@webrtc.org967bfff2013-09-19 05:49:50 +000024using webrtc::VideoSource;
henrike@webrtc.org28e20752013-07-10 00:45:36 +000025using webrtc::VideoTrack;
26using webrtc::VideoTrackInterface;
27
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000028namespace {
29
30class WebRtcVideoTestFrame : public cricket::WebRtcVideoFrame {
31 public:
32 using cricket::WebRtcVideoFrame::SetRotation;
33};
34
35} // namespace
36
37class VideoTrackTest : public testing::Test {
38 public:
39 VideoTrackTest() {
40 static const char kVideoTrackId[] = "track_id";
41
42 channel_manager_.reset(new cricket::ChannelManager(
solenbergfacbbec2015-09-24 00:41:50 -070043 new cricket::FakeMediaEngine(), rtc::Thread::Current()));
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000044 EXPECT_TRUE(channel_manager_->Init());
45 video_track_ = VideoTrack::Create(
46 kVideoTrackId,
47 VideoSource::Create(channel_manager_.get(),
tommi6eca7e32015-12-15 04:27:11 -080048 new webrtc::RemoteVideoCapturer(), NULL, true));
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000049 }
50
51 protected:
52 rtc::scoped_ptr<cricket::ChannelManager> channel_manager_;
53 rtc::scoped_refptr<VideoTrackInterface> video_track_;
54};
55
henrike@webrtc.org28e20752013-07-10 00:45:36 +000056// Test adding renderers to a video track and render to them by providing
wu@webrtc.org967bfff2013-09-19 05:49:50 +000057// frames to the source.
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000058TEST_F(VideoTrackTest, RenderVideo) {
59 // FakeVideoTrackRenderer register itself to |video_track_|
guoweis@webrtc.orgf9a75d92015-03-10 06:37:00 +000060 rtc::scoped_ptr<FakeVideoTrackRenderer> renderer_1(
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000061 new FakeVideoTrackRenderer(video_track_.get()));
guoweis@webrtc.orgf9a75d92015-03-10 06:37:00 +000062
nisse8e8908a2016-02-05 01:52:15 -080063 rtc::VideoSinkInterface<cricket::VideoFrame>* renderer_input =
64 video_track_->GetSink();
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000065 ASSERT_FALSE(renderer_input == NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +000066
henrike@webrtc.org28e20752013-07-10 00:45:36 +000067 cricket::WebRtcVideoFrame frame;
nisse8b1e4312016-01-18 01:46:27 -080068 frame.InitToBlack(123, 123, 0);
nisse8e8908a2016-02-05 01:52:15 -080069 renderer_input->OnFrame(frame);
henrike@webrtc.org28e20752013-07-10 00:45:36 +000070 EXPECT_EQ(1, renderer_1->num_rendered_frames());
71
wu@webrtc.org967bfff2013-09-19 05:49:50 +000072 EXPECT_EQ(123, renderer_1->width());
73 EXPECT_EQ(123, renderer_1->height());
74
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000075 // FakeVideoTrackRenderer register itself to |video_track_|
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +000076 rtc::scoped_ptr<FakeVideoTrackRenderer> renderer_2(
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000077 new FakeVideoTrackRenderer(video_track_.get()));
henrike@webrtc.org28e20752013-07-10 00:45:36 +000078
nisse8e8908a2016-02-05 01:52:15 -080079 renderer_input->OnFrame(frame);
henrike@webrtc.org28e20752013-07-10 00:45:36 +000080
henrike@webrtc.org28e20752013-07-10 00:45:36 +000081 EXPECT_EQ(123, renderer_1->width());
82 EXPECT_EQ(123, renderer_1->height());
henrike@webrtc.org28e20752013-07-10 00:45:36 +000083 EXPECT_EQ(123, renderer_2->width());
84 EXPECT_EQ(123, renderer_2->height());
85
86 EXPECT_EQ(2, renderer_1->num_rendered_frames());
87 EXPECT_EQ(1, renderer_2->num_rendered_frames());
88
guoweis@webrtc.org00c509a2015-03-12 21:37:26 +000089 video_track_->RemoveRenderer(renderer_1.get());
nisse8e8908a2016-02-05 01:52:15 -080090 renderer_input->OnFrame(frame);
henrike@webrtc.org28e20752013-07-10 00:45:36 +000091
92 EXPECT_EQ(2, renderer_1->num_rendered_frames());
93 EXPECT_EQ(2, renderer_2->num_rendered_frames());
94}
nisse81354f52016-01-19 00:23:24 -080095
96// Test that disabling the track results in blacked out frames.
97TEST_F(VideoTrackTest, DisableTrackBlackout) {
98 rtc::scoped_ptr<FakeVideoTrackRenderer> renderer(
99 new FakeVideoTrackRenderer(video_track_.get()));
100
nisse8e8908a2016-02-05 01:52:15 -0800101 rtc::VideoSinkInterface<cricket::VideoFrame>* renderer_input =
102 video_track_->GetSink();
nisse81354f52016-01-19 00:23:24 -0800103 ASSERT_FALSE(renderer_input == NULL);
104
105 cricket::WebRtcVideoFrame frame;
nisse8cb910d2016-02-04 01:01:54 -0800106 frame.InitToBlack(100, 200, 0);
nisse81354f52016-01-19 00:23:24 -0800107 // Make it not all-black
108 frame.GetUPlane()[0] = 0;
109
nisse8e8908a2016-02-05 01:52:15 -0800110 renderer_input->OnFrame(frame);
nisse81354f52016-01-19 00:23:24 -0800111 EXPECT_EQ(1, renderer->num_rendered_frames());
112 EXPECT_FALSE(renderer->black_frame());
113 EXPECT_EQ(100, renderer->width());
114 EXPECT_EQ(200, renderer->height());
115
116 video_track_->set_enabled(false);
nisse8e8908a2016-02-05 01:52:15 -0800117 renderer_input->OnFrame(frame);
nisse81354f52016-01-19 00:23:24 -0800118 EXPECT_EQ(2, renderer->num_rendered_frames());
119 EXPECT_TRUE(renderer->black_frame());
120 EXPECT_EQ(100, renderer->width());
121 EXPECT_EQ(200, renderer->height());
122
123 video_track_->set_enabled(true);
nisse8e8908a2016-02-05 01:52:15 -0800124 renderer_input->OnFrame(frame);
nisse81354f52016-01-19 00:23:24 -0800125 EXPECT_EQ(3, renderer->num_rendered_frames());
126 EXPECT_FALSE(renderer->black_frame());
127 EXPECT_EQ(100, renderer->width());
128 EXPECT_EQ(200, renderer->height());
129}