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::kDefault); |
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::kDefault); |
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::kDefault); |
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::kDefault); |
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::kDefault); |
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::kDefault); |
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::kDefault); |
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::kDefault); |
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 |