| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2016 The WebRTC project authors. All Rights Reserved. | 2 * Copyright 2016 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 4 * 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 47 } | 47 } |
| 48 | 48 |
| 49 SimulatedClock fake_clock_; | 49 SimulatedClock fake_clock_; |
| 50 const VideoReceiveStream::Config config_; | 50 const VideoReceiveStream::Config config_; |
| 51 std::unique_ptr<ReceiveStatisticsProxy> statistics_proxy_; | 51 std::unique_ptr<ReceiveStatisticsProxy> statistics_proxy_; |
| 52 }; | 52 }; |
| 53 | 53 |
| 54 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameIncreasesFramesDecoded) { | 54 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameIncreasesFramesDecoded) { |
| 55 EXPECT_EQ(0u, statistics_proxy_->GetStats().frames_decoded); | 55 EXPECT_EQ(0u, statistics_proxy_->GetStats().frames_decoded); |
| 56 for (uint32_t i = 1; i <= 3; ++i) { | 56 for (uint32_t i = 1; i <= 3; ++i) { |
| 57 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>()); | 57 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(), |
| 58 VideoContentType::UNSPECIFIED); |
| 58 EXPECT_EQ(i, statistics_proxy_->GetStats().frames_decoded); | 59 EXPECT_EQ(i, statistics_proxy_->GetStats().frames_decoded); |
| 59 } | 60 } |
| 60 } | 61 } |
| 61 | 62 |
| 62 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameWithQpResetsFramesDecoded) { | 63 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameWithQpResetsFramesDecoded) { |
| 63 EXPECT_EQ(0u, statistics_proxy_->GetStats().frames_decoded); | 64 EXPECT_EQ(0u, statistics_proxy_->GetStats().frames_decoded); |
| 64 for (uint32_t i = 1; i <= 3; ++i) { | 65 for (uint32_t i = 1; i <= 3; ++i) { |
| 65 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>()); | 66 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(), |
| 67 VideoContentType::UNSPECIFIED); |
| 66 EXPECT_EQ(i, statistics_proxy_->GetStats().frames_decoded); | 68 EXPECT_EQ(i, statistics_proxy_->GetStats().frames_decoded); |
| 67 } | 69 } |
| 68 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(1u)); | 70 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(1u), |
| 71 VideoContentType::UNSPECIFIED); |
| 69 EXPECT_EQ(1u, statistics_proxy_->GetStats().frames_decoded); | 72 EXPECT_EQ(1u, statistics_proxy_->GetStats().frames_decoded); |
| 70 } | 73 } |
| 71 | 74 |
| 72 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameIncreasesQpSum) { | 75 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameIncreasesQpSum) { |
| 73 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); | 76 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); |
| 74 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(3u)); | 77 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(3u), |
| 78 VideoContentType::UNSPECIFIED); |
| 75 EXPECT_EQ(rtc::Optional<uint64_t>(3u), statistics_proxy_->GetStats().qp_sum); | 79 EXPECT_EQ(rtc::Optional<uint64_t>(3u), statistics_proxy_->GetStats().qp_sum); |
| 76 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(127u)); | 80 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(127u), |
| 81 VideoContentType::UNSPECIFIED); |
| 77 EXPECT_EQ(rtc::Optional<uint64_t>(130u), | 82 EXPECT_EQ(rtc::Optional<uint64_t>(130u), |
| 78 statistics_proxy_->GetStats().qp_sum); | 83 statistics_proxy_->GetStats().qp_sum); |
| 79 } | 84 } |
| 80 | 85 |
| 81 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameWithoutQpQpSumWontExist) { | 86 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameWithoutQpQpSumWontExist) { |
| 82 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); | 87 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); |
| 83 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>()); | 88 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(), |
| 89 VideoContentType::UNSPECIFIED); |
| 84 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); | 90 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); |
| 85 } | 91 } |
| 86 | 92 |
| 87 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameWithoutQpResetsQpSum) { | 93 TEST_F(ReceiveStatisticsProxyTest, OnDecodedFrameWithoutQpResetsQpSum) { |
| 88 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); | 94 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); |
| 89 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(3u)); | 95 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(3u), |
| 96 VideoContentType::UNSPECIFIED); |
| 90 EXPECT_EQ(rtc::Optional<uint64_t>(3u), statistics_proxy_->GetStats().qp_sum); | 97 EXPECT_EQ(rtc::Optional<uint64_t>(3u), statistics_proxy_->GetStats().qp_sum); |
| 91 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>()); | 98 statistics_proxy_->OnDecodedFrame(rtc::Optional<uint8_t>(), |
| 99 VideoContentType::UNSPECIFIED); |
| 92 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); | 100 EXPECT_EQ(rtc::Optional<uint64_t>(), statistics_proxy_->GetStats().qp_sum); |
| 93 } | 101 } |
| 94 | 102 |
| 95 TEST_F(ReceiveStatisticsProxyTest, OnRenderedFrameIncreasesFramesRendered) { | 103 TEST_F(ReceiveStatisticsProxyTest, OnRenderedFrameIncreasesFramesRendered) { |
| 96 EXPECT_EQ(0u, statistics_proxy_->GetStats().frames_rendered); | 104 EXPECT_EQ(0u, statistics_proxy_->GetStats().frames_rendered); |
| 97 webrtc::VideoFrame frame( | 105 webrtc::VideoFrame frame(webrtc::I420Buffer::Create(1, 1), 0, 0, |
| 98 webrtc::I420Buffer::Create(1, 1), 0, 0, webrtc::kVideoRotation_0); | 106 webrtc::kVideoRotation_0); |
| 99 for (uint32_t i = 1; i <= 3; ++i) { | 107 for (uint32_t i = 1; i <= 3; ++i) { |
| 100 statistics_proxy_->OnRenderedFrame(frame); | 108 statistics_proxy_->OnRenderedFrame(frame); |
| 101 EXPECT_EQ(i, statistics_proxy_->GetStats().frames_rendered); | 109 EXPECT_EQ(i, statistics_proxy_->GetStats().frames_rendered); |
| 102 } | 110 } |
| 103 } | 111 } |
| 104 | 112 |
| 105 TEST_F(ReceiveStatisticsProxyTest, GetStatsReportsSsrc) { | 113 TEST_F(ReceiveStatisticsProxyTest, GetStatsReportsSsrc) { |
| 106 EXPECT_EQ(kRemoteSsrc, statistics_proxy_->GetStats().ssrc); | 114 EXPECT_EQ(kRemoteSsrc, statistics_proxy_->GetStats().ssrc); |
| 107 } | 115 } |
| 108 | 116 |
| (...skipping 279 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 388 codec_info.codecType = kVideoCodecVP8; | 396 codec_info.codecType = kVideoCodecVP8; |
| 389 | 397 |
| 390 for (int i = 0; i < kMinRequiredSamples; ++i) | 398 for (int i = 0; i < kMinRequiredSamples; ++i) |
| 391 statistics_proxy_->OnPreDecode(encoded_image, &codec_info); | 399 statistics_proxy_->OnPreDecode(encoded_image, &codec_info); |
| 392 | 400 |
| 393 statistics_proxy_.reset(); | 401 statistics_proxy_.reset(); |
| 394 EXPECT_EQ(0, metrics::NumSamples("WebRTC.Video.Decoded.Vp8.Qp")); | 402 EXPECT_EQ(0, metrics::NumSamples("WebRTC.Video.Decoded.Vp8.Qp")); |
| 395 } | 403 } |
| 396 | 404 |
| 397 } // namespace webrtc | 405 } // namespace webrtc |
| OLD | NEW |