| 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 |