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 "base/message_loop/message_loop.h" | 5 #include "base/message_loop/message_loop.h" |
6 #include "base/run_loop.h" | 6 #include "base/run_loop.h" |
7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
8 #include "base/thread_task_runner_handle.h" | 8 #include "base/thread_task_runner_handle.h" |
9 #include "content/child/child_process.h" | 9 #include "content/child/child_process.h" |
10 #include "content/renderer/media/media_stream_video_track.h" | 10 #include "content/renderer/media/media_stream_video_track.h" |
(...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
120 scoped_ptr<MediaStreamVideoTrack> track(CreateTrack()); | 120 scoped_ptr<MediaStreamVideoTrack> track(CreateTrack()); |
121 EXPECT_EQ(1, NumberOfSuccessConstraintsCallbacks()); | 121 EXPECT_EQ(1, NumberOfSuccessConstraintsCallbacks()); |
122 | 122 |
123 MockMediaStreamVideoSink sink; | 123 MockMediaStreamVideoSink sink; |
124 track->AddSink(&sink, sink.GetDeliverFrameCB()); | 124 track->AddSink(&sink, sink.GetDeliverFrameCB()); |
125 base::RunLoop run_loop; | 125 base::RunLoop run_loop; |
126 base::Closure quit_closure = run_loop.QuitClosure(); | 126 base::Closure quit_closure = run_loop.QuitClosure(); |
127 EXPECT_CALL(sink, OnVideoFrame()).WillOnce( | 127 EXPECT_CALL(sink, OnVideoFrame()).WillOnce( |
128 RunClosure(quit_closure)); | 128 RunClosure(quit_closure)); |
129 cricket::WebRtcVideoFrame webrtc_frame; | 129 cricket::WebRtcVideoFrame webrtc_frame; |
130 webrtc_frame.InitToBlack(320, 240, 1, 1, 0, 1); | 130 webrtc_frame.InitToBlack(320, 240, 1, 1, 1); |
131 source()->RenderInterfaceForTest()->RenderFrame(&webrtc_frame); | 131 source()->RenderInterfaceForTest()->RenderFrame(&webrtc_frame); |
132 run_loop.Run(); | 132 run_loop.Run(); |
133 | 133 |
134 EXPECT_EQ(1, sink.number_of_frames()); | 134 EXPECT_EQ(1, sink.number_of_frames()); |
135 track->RemoveSink(&sink); | 135 track->RemoveSink(&sink); |
136 } | 136 } |
137 | 137 |
138 TEST_F(MediaStreamRemoteVideoSourceTest, RemoteTrackStop) { | 138 TEST_F(MediaStreamRemoteVideoSourceTest, RemoteTrackStop) { |
139 scoped_ptr<MediaStreamVideoTrack> track(CreateTrack()); | 139 scoped_ptr<MediaStreamVideoTrack> track(CreateTrack()); |
140 | 140 |
141 MockMediaStreamVideoSink sink; | 141 MockMediaStreamVideoSink sink; |
142 track->AddSink(&sink, sink.GetDeliverFrameCB()); | 142 track->AddSink(&sink, sink.GetDeliverFrameCB()); |
143 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateLive, sink.state()); | 143 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateLive, sink.state()); |
144 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateLive, | 144 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateLive, |
145 webkit_source().readyState()); | 145 webkit_source().readyState()); |
146 StopWebRtcTrack(); | 146 StopWebRtcTrack(); |
147 base::RunLoop().RunUntilIdle(); | 147 base::RunLoop().RunUntilIdle(); |
148 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateEnded, | 148 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateEnded, |
149 webkit_source().readyState()); | 149 webkit_source().readyState()); |
150 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateEnded, sink.state()); | 150 EXPECT_EQ(blink::WebMediaStreamSource::ReadyStateEnded, sink.state()); |
151 | 151 |
152 track->RemoveSink(&sink); | 152 track->RemoveSink(&sink); |
153 } | 153 } |
154 | 154 |
155 } // namespace content | 155 } // namespace content |
OLD | NEW |