Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "media/base/download_rate_monitor.h" | 5 #include "media/base/download_rate_monitor.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "testing/gmock/include/gmock/gmock.h" | 9 #include "testing/gmock/include/gmock/gmock.h" |
| 10 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 36 int bytes_per_packet, | 36 int bytes_per_packet, |
| 37 int ms_between_packets, | 37 int ms_between_packets, |
| 38 int number_of_packets) { | 38 int number_of_packets) { |
| 39 int bytes_buffered = starting_bytes; | 39 int bytes_buffered = starting_bytes; |
| 40 base::Time packet_time = base::Time::FromDoubleT(starting_time); | 40 base::Time packet_time = base::Time::FromDoubleT(starting_time); |
| 41 | 41 |
| 42 monitor_.SetNetworkActivity(true); | 42 monitor_.SetNetworkActivity(true); |
| 43 // Loop executes (number_of_packets + 1) times because a packet needs a | 43 // Loop executes (number_of_packets + 1) times because a packet needs a |
| 44 // starting and end point. | 44 // starting and end point. |
| 45 for (int i = 0; i < number_of_packets + 1; ++i) { | 45 for (int i = 0; i < number_of_packets + 1; ++i) { |
| 46 monitor_.SetBufferedBytes(bytes_buffered, packet_time); | 46 monitor_.SetBufferedBytes(bytes_buffered, packet_time); |
|
acolwell GONE FROM CHROMIUM
2012/01/05 22:33:56
Consider creating a helper object that models how
vrk (LEFT CHROMIUM)
2012/01/09 19:01:18
Made two objects, a FakeFilterHost and FakeDataSou
| |
| 47 packet_time += base::TimeDelta::FromMilliseconds(ms_between_packets); | 47 packet_time += base::TimeDelta::FromMilliseconds(ms_between_packets); |
| 48 bytes_buffered += bytes_per_packet; | 48 bytes_buffered += bytes_per_packet; |
| 49 } | 49 } |
| 50 monitor_.SetNetworkActivity(false); | |
| 51 return bytes_buffered; | 50 return bytes_buffered; |
| 52 } | 51 } |
| 53 | 52 |
| 54 void StartMonitor(int bitrate) { | 53 void StartMonitor(int bitrate) { |
| 55 StartMonitor(bitrate, false, false); | 54 StartMonitor(bitrate, false, false); |
| 56 } | 55 } |
| 57 | 56 |
| 58 void StartMonitor(int bitrate, bool streaming, bool local_source) { | 57 void StartMonitor(int bitrate, bool streaming, bool local_source) { |
| 59 monitor_.Start(base::Bind(&DownloadRateMonitorTest::CanPlayThrough, | 58 monitor_.Start(base::Bind(&DownloadRateMonitorTest::CanPlayThrough, |
| 60 base::Unretained(this)), bitrate, streaming, local_source); | 59 base::Unretained(this)), bitrate, streaming, local_source); |
| 61 } | 60 } |
| 62 | 61 |
| 63 DownloadRateMonitor monitor_; | 62 DownloadRateMonitor monitor_; |
| 64 | 63 |
| 65 private: | 64 private: |
| 66 DISALLOW_COPY_AND_ASSIGN(DownloadRateMonitorTest); | 65 DISALLOW_COPY_AND_ASSIGN(DownloadRateMonitorTest); |
| 67 }; | 66 }; |
| 68 | 67 |
| 69 TEST_F(DownloadRateMonitorTest, DownloadRateGreaterThanBitrate) { | 68 TEST_F(DownloadRateMonitorTest, DownloadRateGreaterThanBitrate) { |
| 70 static const int media_bitrate = 1024 * 1024 * 8; | 69 static const int media_bitrate = 1024 * 1024 * 8; |
| 71 | 70 |
| 72 // Simulate downloading at double the media's bitrate. | 71 // Simulate downloading at double the media's bitrate. |
| 73 StartMonitor(media_bitrate); | 72 StartMonitor(media_bitrate); |
| 74 EXPECT_CALL(*this, CanPlayThrough()); | 73 EXPECT_CALL(*this, CanPlayThrough()); |
| 75 SimulateNetwork(1, 0, 2 * media_bitrate / 8, 1000, 10); | 74 SimulateNetwork(1, 0, 2 * media_bitrate / 8, 1000, 10); |
| 76 } | 75 } |
| 77 | 76 |
| 78 // If the user pauses and the pipeline stops downloading data, make sure the | 77 TEST_F(DownloadRateMonitorTest, DownloadRateGreaterThanBitrate_Defer) { |
| 79 // DownloadRateMonitor understands that the download is not stalling. | |
| 80 TEST_F(DownloadRateMonitorTest, DownloadRateGreaterThanBitrate_Pause) { | |
|
acolwell GONE FROM CHROMIUM
2012/01/05 22:33:56
Based on what the comment sayd, I think this test
vrk (LEFT CHROMIUM)
2012/01/09 19:01:18
Ahhh, now I remember why I deleted this. The test
| |
| 81 static const int media_bitrate = 1024 * 1024 * 8; | 78 static const int media_bitrate = 1024 * 1024 * 8; |
| 82 static const int download_byte_rate = 1.1 * media_bitrate / 8; | 79 static const int download_byte_rate = 1.1 * media_bitrate / 8; |
| 83 | 80 |
| 84 // Start downloading faster than the media's bitrate. | 81 // Start downloading faster than the media's bitrate. |
| 85 StartMonitor(media_bitrate); | 82 StartMonitor(media_bitrate); |
| 83 SimulateNetwork(1, 0, download_byte_rate, 1000, 2); | |
| 84 | |
| 85 // Now defer download because the client has decided enough data has been | |
| 86 // buffered. | |
| 86 EXPECT_CALL(*this, CanPlayThrough()); | 87 EXPECT_CALL(*this, CanPlayThrough()); |
| 87 int buffered = SimulateNetwork(1, 0, download_byte_rate, 1000, 2); | 88 monitor_.SetNetworkActivity(false); |
| 88 | |
| 89 // Then "pause" for 3 minutes and continue downloading at same rate. | |
| 90 SimulateNetwork(60 * 3, buffered, download_byte_rate, 1000, 4); | |
| 91 } | 89 } |
| 92 | 90 |
| 93 TEST_F(DownloadRateMonitorTest, DownloadRateGreaterThanBitrate_SeekForward) { | 91 TEST_F(DownloadRateMonitorTest, DownloadRateGreaterThanBitrate_SeekForward) { |
| 94 static const int media_bitrate = 1024 * 1024 * 8; | 92 static const int media_bitrate = 1024 * 1024 * 8; |
| 95 static const int download_byte_rate = 1.1 * media_bitrate / 8; | 93 static const int download_byte_rate = 1.1 * media_bitrate / 8; |
| 96 | 94 |
| 97 // Start downloading faster than the media's bitrate. | 95 // Start downloading faster than the media's bitrate. |
| 98 EXPECT_CALL(*this, CanPlayThrough()); | 96 EXPECT_CALL(*this, CanPlayThrough()); |
| 99 StartMonitor(media_bitrate); | 97 StartMonitor(media_bitrate); |
| 100 SimulateNetwork(1, 0, download_byte_rate, 1000, 2); | 98 SimulateNetwork(1, 0, download_byte_rate, 1000, 2); |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 156 static const int seconds_of_data = 20; | 154 static const int seconds_of_data = 20; |
| 157 static const int media_bitrate = kMediaSizeInBytes * 8 / seconds_of_data; | 155 static const int media_bitrate = kMediaSizeInBytes * 8 / seconds_of_data; |
| 158 | 156 |
| 159 // Simulate downloading entire video at half the bitrate of the video. | 157 // Simulate downloading entire video at half the bitrate of the video. |
| 160 StartMonitor(media_bitrate); | 158 StartMonitor(media_bitrate); |
| 161 EXPECT_CALL(*this, CanPlayThrough()); | 159 EXPECT_CALL(*this, CanPlayThrough()); |
| 162 SimulateNetwork(1, 0, media_bitrate / 8 / 2, 1000, seconds_of_data * 2); | 160 SimulateNetwork(1, 0, media_bitrate / 8 / 2, 1000, seconds_of_data * 2); |
| 163 } | 161 } |
| 164 | 162 |
| 165 } // namespace media | 163 } // namespace media |
| OLD | NEW |