OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "content/renderer/media/webrtc/media_stream_remote_video_source.h" | 5 #include "content/renderer/media/webrtc/media_stream_remote_video_source.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
10 #include "base/run_loop.h" | 10 #include "base/run_loop.h" |
(...skipping 14 matching lines...) Expand all Loading... |
25 ACTION_P(RunClosure, closure) { | 25 ACTION_P(RunClosure, closure) { |
26 closure.Run(); | 26 closure.Run(); |
27 } | 27 } |
28 | 28 |
29 class MediaStreamRemoteVideoSourceUnderTest | 29 class MediaStreamRemoteVideoSourceUnderTest |
30 : public MediaStreamRemoteVideoSource { | 30 : public MediaStreamRemoteVideoSource { |
31 public: | 31 public: |
32 explicit MediaStreamRemoteVideoSourceUnderTest( | 32 explicit MediaStreamRemoteVideoSourceUnderTest( |
33 scoped_ptr<TrackObserver> observer) | 33 scoped_ptr<TrackObserver> observer) |
34 : MediaStreamRemoteVideoSource(std::move(observer)) {} | 34 : MediaStreamRemoteVideoSource(std::move(observer)) {} |
35 using MediaStreamRemoteVideoSource::RenderInterfaceForTest; | 35 using MediaStreamRemoteVideoSource::SinkInterfaceForTest; |
36 }; | 36 }; |
37 | 37 |
38 class MediaStreamRemoteVideoSourceTest | 38 class MediaStreamRemoteVideoSourceTest |
39 : public ::testing::Test { | 39 : public ::testing::Test { |
40 public: | 40 public: |
41 MediaStreamRemoteVideoSourceTest() | 41 MediaStreamRemoteVideoSourceTest() |
42 : child_process_(new ChildProcess()), | 42 : child_process_(new ChildProcess()), |
43 mock_factory_(new MockPeerConnectionDependencyFactory()), | 43 mock_factory_(new MockPeerConnectionDependencyFactory()), |
44 webrtc_video_track_(mock_factory_->CreateLocalVideoTrack( | 44 webrtc_video_track_(mock_factory_->CreateLocalVideoTrack( |
45 "test", | 45 "test", |
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
124 EXPECT_EQ(1, NumberOfSuccessConstraintsCallbacks()); | 124 EXPECT_EQ(1, NumberOfSuccessConstraintsCallbacks()); |
125 | 125 |
126 MockMediaStreamVideoSink sink; | 126 MockMediaStreamVideoSink sink; |
127 track->AddSink(&sink, sink.GetDeliverFrameCB()); | 127 track->AddSink(&sink, sink.GetDeliverFrameCB()); |
128 base::RunLoop run_loop; | 128 base::RunLoop run_loop; |
129 base::Closure quit_closure = run_loop.QuitClosure(); | 129 base::Closure quit_closure = run_loop.QuitClosure(); |
130 EXPECT_CALL(sink, OnVideoFrame()).WillOnce( | 130 EXPECT_CALL(sink, OnVideoFrame()).WillOnce( |
131 RunClosure(quit_closure)); | 131 RunClosure(quit_closure)); |
132 cricket::WebRtcVideoFrame webrtc_frame; | 132 cricket::WebRtcVideoFrame webrtc_frame; |
133 webrtc_frame.InitToBlack(320, 240, 1); | 133 webrtc_frame.InitToBlack(320, 240, 1); |
134 source()->RenderInterfaceForTest()->RenderFrame(&webrtc_frame); | 134 source()->SinkInterfaceForTest()->OnFrame(webrtc_frame); |
135 run_loop.Run(); | 135 run_loop.Run(); |
136 | 136 |
137 EXPECT_EQ(1, sink.number_of_frames()); | 137 EXPECT_EQ(1, sink.number_of_frames()); |
138 track->RemoveSink(&sink); | 138 track->RemoveSink(&sink); |
139 } | 139 } |
140 | 140 |
141 TEST_F(MediaStreamRemoteVideoSourceTest, RemoteTrackStop) { | 141 TEST_F(MediaStreamRemoteVideoSourceTest, RemoteTrackStop) { |
142 scoped_ptr<MediaStreamVideoTrack> track(CreateTrack()); | 142 scoped_ptr<MediaStreamVideoTrack> track(CreateTrack()); |
143 | 143 |
144 MockMediaStreamVideoSink sink; | 144 MockMediaStreamVideoSink sink; |
145 track->AddSink(&sink, sink.GetDeliverFrameCB()); | 145 track->AddSink(&sink, sink.GetDeliverFrameCB()); |
146 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateLive, sink.state()); | 146 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateLive, sink.state()); |
147 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateLive, | 147 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateLive, |
148 webkit_source().getReadyState()); | 148 webkit_source().getReadyState()); |
149 StopWebRtcTrack(); | 149 StopWebRtcTrack(); |
150 base::RunLoop().RunUntilIdle(); | 150 base::RunLoop().RunUntilIdle(); |
151 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateEnded, | 151 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateEnded, |
152 webkit_source().getReadyState()); | 152 webkit_source().getReadyState()); |
153 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateEnded, sink.state()); | 153 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateEnded, sink.state()); |
154 | 154 |
155 track->RemoveSink(&sink); | 155 track->RemoveSink(&sink); |
156 } | 156 } |
157 | 157 |
158 } // namespace content | 158 } // namespace content |
OLD | NEW |