| Index: webrtc/media/base/videocapturer_unittest.cc | 
| diff --git a/webrtc/media/base/videocapturer_unittest.cc b/webrtc/media/base/videocapturer_unittest.cc | 
| index f385d59551f84d740fc792704cca51a89bd620e2..cbd92c5b8c32cf804b85274c652b88fb5b7b02ce 100644 | 
| --- a/webrtc/media/base/videocapturer_unittest.cc | 
| +++ b/webrtc/media/base/videocapturer_unittest.cc | 
| @@ -35,13 +35,29 @@ | 
| public testing::Test { | 
| public: | 
| VideoCapturerTest() | 
| -      : capture_state_(cricket::CS_STOPPED), num_state_changes_(0) { | 
| +      : capture_state_(cricket::CS_STOPPED), | 
| +        num_state_changes_(0), | 
| +        video_frames_received_(0), | 
| +        expects_rotation_applied_(true) { | 
| +    capturer_.SignalVideoFrame.connect(this, &VideoCapturerTest::OnVideoFrame); | 
| capturer_.SignalStateChange.connect(this, | 
| &VideoCapturerTest::OnStateChange); | 
| -    capturer_.AddOrUpdateSink(&renderer_, rtc::VideoSinkWants()); | 
| +  } | 
| + | 
| +  void set_expected_compensation(bool compensation) { | 
| +    expects_rotation_applied_ = compensation; | 
| } | 
|  | 
| protected: | 
| +  void OnVideoFrame(cricket::VideoCapturer*, const cricket::VideoFrame* frame) { | 
| +    ++video_frames_received_; | 
| +    if (expects_rotation_applied_) { | 
| +      EXPECT_EQ(webrtc::kVideoRotation_0, frame->GetRotation()); | 
| +    } else { | 
| +      EXPECT_EQ(capturer_.GetRotation(), frame->GetRotation()); | 
| +    } | 
| +    renderer_.RenderFrame(frame); | 
| +  } | 
| void OnStateChange(cricket::VideoCapturer*, | 
| cricket::CaptureState capture_state) { | 
| capture_state_ = capture_state; | 
| @@ -49,10 +65,14 @@ | 
| } | 
| cricket::CaptureState capture_state() { return capture_state_; } | 
| int num_state_changes() { return num_state_changes_; } | 
| +  int video_frames_received() const { | 
| +    return video_frames_received_; | 
| +  } | 
|  | 
| cricket::FakeVideoCapturer capturer_; | 
| cricket::CaptureState capture_state_; | 
| int num_state_changes_; | 
| +  int video_frames_received_; | 
| cricket::FakeVideoRenderer renderer_; | 
| bool expects_rotation_applied_; | 
| }; | 
| @@ -129,9 +149,9 @@ | 
| cricket::VideoFormat::FpsToInterval(30), | 
| cricket::FOURCC_I420))); | 
| EXPECT_TRUE(capturer_.IsRunning()); | 
| -  EXPECT_EQ(0, renderer_.num_rendered_frames()); | 
| -  EXPECT_TRUE(capturer_.CaptureFrame()); | 
| -  EXPECT_EQ(1, renderer_.num_rendered_frames()); | 
| +  EXPECT_EQ(0, video_frames_received()); | 
| +  EXPECT_TRUE(capturer_.CaptureFrame()); | 
| +  EXPECT_EQ(1, video_frames_received()); | 
| EXPECT_FALSE(capturer_.IsMuted()); | 
|  | 
| // Mute the camera and expect black output frame. | 
| @@ -141,13 +161,13 @@ | 
| EXPECT_TRUE(capturer_.CaptureFrame()); | 
| EXPECT_TRUE(renderer_.black_frame()); | 
| } | 
| -  EXPECT_EQ(32, renderer_.num_rendered_frames()); | 
| +  EXPECT_EQ(32, video_frames_received()); | 
| EXPECT_EQ_WAIT(cricket::CS_PAUSED, | 
| capturer_.capture_state(), kTimeout); | 
|  | 
| // Verify that the camera is off. | 
| EXPECT_FALSE(capturer_.CaptureFrame()); | 
| -  EXPECT_EQ(32, renderer_.num_rendered_frames()); | 
| +  EXPECT_EQ(32, video_frames_received()); | 
|  | 
| // Unmute the camera and expect non-black output frame. | 
| capturer_.MuteToBlackThenPause(false); | 
| @@ -156,7 +176,7 @@ | 
| capturer_.capture_state(), kTimeout); | 
| EXPECT_TRUE(capturer_.CaptureFrame()); | 
| EXPECT_FALSE(renderer_.black_frame()); | 
| -  EXPECT_EQ(33, renderer_.num_rendered_frames()); | 
| +  EXPECT_EQ(33, video_frames_received()); | 
| } | 
|  | 
| TEST_F(VideoCapturerTest, ScreencastScaledOddWidth) { | 
| @@ -183,7 +203,7 @@ | 
| EXPECT_EQ(kHeight, renderer_.height()); | 
| } | 
|  | 
| -TEST_F(VideoCapturerTest, TestRotationAppliedBySource) { | 
| +TEST_F(VideoCapturerTest, TestRotationPending) { | 
| int kWidth = 800; | 
| int kHeight = 400; | 
| int frame_count = 0; | 
| @@ -194,7 +214,6 @@ | 
| cricket::FOURCC_I420)); | 
|  | 
| capturer_.ResetSupportedFormats(formats); | 
| - | 
| // capturer_ should compensate rotation as default. | 
| capturer_.UpdateAspectRatio(400, 200); | 
|  | 
| @@ -215,7 +234,6 @@ | 
| // Swapped width and height | 
| EXPECT_EQ(kWidth, renderer_.height()); | 
| EXPECT_EQ(kHeight, renderer_.width()); | 
| -  EXPECT_EQ(webrtc::kVideoRotation_0, renderer_.rotation()); | 
|  | 
| capturer_.SetRotation(webrtc::kVideoRotation_270); | 
| EXPECT_TRUE(capturer_.CaptureFrame()); | 
| @@ -223,7 +241,6 @@ | 
| // Swapped width and height | 
| EXPECT_EQ(kWidth, renderer_.height()); | 
| EXPECT_EQ(kHeight, renderer_.width()); | 
| -  EXPECT_EQ(webrtc::kVideoRotation_0, renderer_.rotation()); | 
|  | 
| capturer_.SetRotation(webrtc::kVideoRotation_180); | 
| EXPECT_TRUE(capturer_.CaptureFrame()); | 
| @@ -231,10 +248,9 @@ | 
| // Back to normal width and height | 
| EXPECT_EQ(kWidth, renderer_.width()); | 
| EXPECT_EQ(kHeight, renderer_.height()); | 
| -  EXPECT_EQ(webrtc::kVideoRotation_0, renderer_.rotation()); | 
| -} | 
| - | 
| -TEST_F(VideoCapturerTest, TestRotationAppliedBySink) { | 
| +} | 
| + | 
| +TEST_F(VideoCapturerTest, TestRotationApplied) { | 
| int kWidth = 800; | 
| int kHeight = 400; | 
|  | 
| @@ -244,12 +260,10 @@ | 
| cricket::FOURCC_I420)); | 
|  | 
| capturer_.ResetSupportedFormats(formats); | 
| -  rtc::VideoSinkWants wants; | 
| // capturer_ should not compensate rotation. | 
| -  wants.rotation_applied = false; | 
| -  capturer_.AddOrUpdateSink(&renderer_, wants); | 
| - | 
| +  capturer_.SetApplyRotation(false); | 
| capturer_.UpdateAspectRatio(400, 200); | 
| +  set_expected_compensation(false); | 
|  | 
| EXPECT_EQ(cricket::CS_RUNNING, | 
| capturer_.Start(cricket::VideoFormat( | 
| @@ -267,64 +281,18 @@ | 
| capturer_.SetRotation(webrtc::kVideoRotation_0); | 
| EXPECT_TRUE(capturer_.CaptureFrame()); | 
| EXPECT_EQ(++frame_count, renderer_.num_rendered_frames()); | 
| -  EXPECT_EQ(capturer_.GetRotation(), renderer_.rotation()); | 
|  | 
| capturer_.SetRotation(webrtc::kVideoRotation_90); | 
| EXPECT_TRUE(capturer_.CaptureFrame()); | 
| EXPECT_EQ(++frame_count, renderer_.num_rendered_frames()); | 
| -  EXPECT_EQ(capturer_.GetRotation(), renderer_.rotation()); | 
|  | 
| capturer_.SetRotation(webrtc::kVideoRotation_180); | 
| EXPECT_TRUE(capturer_.CaptureFrame()); | 
| EXPECT_EQ(++frame_count, renderer_.num_rendered_frames()); | 
| -  EXPECT_EQ(capturer_.GetRotation(), renderer_.rotation()); | 
|  | 
| capturer_.SetRotation(webrtc::kVideoRotation_270); | 
| EXPECT_TRUE(capturer_.CaptureFrame()); | 
| EXPECT_EQ(++frame_count, renderer_.num_rendered_frames()); | 
| -  EXPECT_EQ(capturer_.GetRotation(), renderer_.rotation()); | 
| -} | 
| - | 
| -TEST_F(VideoCapturerTest, TestRotationAppliedBySourceWhenDifferentWants) { | 
| -  int kWidth = 800; | 
| -  int kHeight = 400; | 
| - | 
| -  std::vector<cricket::VideoFormat> formats; | 
| -  formats.push_back(cricket::VideoFormat(kWidth, kHeight, | 
| -                                         cricket::VideoFormat::FpsToInterval(5), | 
| -                                         cricket::FOURCC_I420)); | 
| - | 
| -  capturer_.ResetSupportedFormats(formats); | 
| -  rtc::VideoSinkWants wants; | 
| -  // capturer_ should not compensate rotation. | 
| -  wants.rotation_applied = false; | 
| -  capturer_.AddOrUpdateSink(&renderer_, wants); | 
| - | 
| -  capturer_.UpdateAspectRatio(400, 200); | 
| - | 
| -  EXPECT_EQ(cricket::CS_RUNNING, | 
| -            capturer_.Start(cricket::VideoFormat( | 
| -                kWidth, kHeight, cricket::VideoFormat::FpsToInterval(30), | 
| -                cricket::FOURCC_I420))); | 
| -  EXPECT_TRUE(capturer_.IsRunning()); | 
| -  EXPECT_EQ(0, renderer_.num_rendered_frames()); | 
| - | 
| -  int frame_count = 0; | 
| -  capturer_.SetRotation(webrtc::kVideoRotation_90); | 
| -  EXPECT_TRUE(capturer_.CaptureFrame()); | 
| -  EXPECT_EQ(++frame_count, renderer_.num_rendered_frames()); | 
| -  EXPECT_EQ(capturer_.GetRotation(), renderer_.rotation()); | 
| - | 
| -  // Add another sink that wants frames to be rotated. | 
| -  cricket::FakeVideoRenderer renderer2; | 
| -  wants.rotation_applied = true; | 
| -  capturer_.AddOrUpdateSink(&renderer2, wants); | 
| - | 
| -  EXPECT_TRUE(capturer_.CaptureFrame()); | 
| -  EXPECT_EQ(++frame_count, renderer_.num_rendered_frames()); | 
| -  EXPECT_EQ(1, renderer2.num_rendered_frames()); | 
| -  EXPECT_EQ(webrtc::kVideoRotation_0, renderer_.rotation()); | 
| -  EXPECT_EQ(webrtc::kVideoRotation_0, renderer2.rotation()); | 
| } | 
|  | 
| TEST_F(VideoCapturerTest, ScreencastScaledSuperLarge) { | 
| @@ -746,6 +714,25 @@ | 
| EXPECT_EQ(640, best.width); | 
| EXPECT_EQ(360, best.height); | 
| } | 
| + | 
| +// If HAVE_WEBRTC_VIDEO is not defined the video capturer will not be able to | 
| +// provide OnVideoFrame-callbacks since they require cricket::CapturedFrame to | 
| +// be decoded as a cricket::VideoFrame (i.e. an I420 frame). This functionality | 
| +// only exist if HAVE_WEBRTC_VIDEO is defined below. I420 frames are also a | 
| +// requirement for the VideoProcessors so they will not be called either. | 
| +#if defined(HAVE_WEBRTC_VIDEO) | 
| +TEST_F(VideoCapturerTest, VideoFrame) { | 
| +  EXPECT_EQ(cricket::CS_RUNNING, capturer_.Start(cricket::VideoFormat( | 
| +      640, | 
| +      480, | 
| +      cricket::VideoFormat::FpsToInterval(30), | 
| +      cricket::FOURCC_I420))); | 
| +  EXPECT_TRUE(capturer_.IsRunning()); | 
| +  EXPECT_EQ(0, video_frames_received()); | 
| +  EXPECT_TRUE(capturer_.CaptureFrame()); | 
| +  EXPECT_EQ(1, video_frames_received()); | 
| +} | 
| +#endif  // HAVE_WEBRTC_VIDEO | 
|  | 
| bool HdFormatInList(const std::vector<cricket::VideoFormat>& formats) { | 
| for (std::vector<cricket::VideoFormat>::const_iterator found = | 
|  |