Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(480)

Unified Diff: media/base/audio_fifo_unittest.cc

Issue 10915123: Adds media::AudioPullFifo class to Chrome. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: test Created 8 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « media/base/audio_fifo.cc ('k') | media/base/audio_pull_fifo.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/base/audio_fifo_unittest.cc
diff --git a/media/base/audio_fifo_unittest.cc b/media/base/audio_fifo_unittest.cc
index 00b642bff1c8738932e84bf82d7c3a7771b28c1e..dd5ffd936de77a3af0870791a88646fc51728b20 100644
--- a/media/base/audio_fifo_unittest.cc
+++ b/media/base/audio_fifo_unittest.cc
@@ -2,6 +2,8 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+// TODO(henrika): add test which included |start_frame| in Consume() call.
+
#include "media/base/audio_fifo.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -26,11 +28,10 @@ TEST_F(AudioFifoTest, Construct) {
static const int kChannels = 6;
static const int kMaxFrameCount = 128;
AudioFifo fifo(kChannels, kMaxFrameCount);
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
+ EXPECT_EQ(fifo.frames(), 0);
}
// Pushes audio bus objects to a FIFO and fill it up to different degrees.
-// Also, verify that it is not possible to overflow the FIFO.
TEST_F(AudioFifoTest, Push) {
static const int kChannels = 2;
static const int kMaxFrameCount = 128;
@@ -38,65 +39,50 @@ TEST_F(AudioFifoTest, Push) {
{
SCOPED_TRACE("Push 50%");
scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, kMaxFrameCount / 2);
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), bus->frames());
+ EXPECT_EQ(fifo.frames(), 0);
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), bus->frames());
fifo.Clear();
}
{
SCOPED_TRACE("Push 100%");
scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, kMaxFrameCount);
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), bus->frames());
+ EXPECT_EQ(fifo.frames(), 0);
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), bus->frames());
fifo.Clear();
}
- {
- SCOPED_TRACE("Overflow");
- scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, kMaxFrameCount + 1);
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
- EXPECT_FALSE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
- }
}
// Consumes audio bus objects from a FIFO and empty it to different degrees.
-// Also, verify that it is not possible to ask for more data than the FIFO
-// contains (corresponds to underrun).
TEST_F(AudioFifoTest, Consume) {
static const int kChannels = 2;
static const int kMaxFrameCount = 128;
AudioFifo fifo(kChannels, kMaxFrameCount);
{
scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, kMaxFrameCount);
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), kMaxFrameCount);
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), kMaxFrameCount);
}
{
SCOPED_TRACE("Consume 50%");
scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, kMaxFrameCount / 2);
- EXPECT_TRUE(fifo.Consume(bus.get(), bus->frames()));
- EXPECT_TRUE(fifo.frames_in_fifo() == bus->frames());
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), kMaxFrameCount);
+ fifo.Consume(bus.get(), 0, bus->frames());
+ EXPECT_TRUE(fifo.frames() == bus->frames());
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), kMaxFrameCount);
}
{
SCOPED_TRACE("Consume 100%");
scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, kMaxFrameCount);
- EXPECT_TRUE(fifo.Consume(bus.get(), bus->frames()));
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), kMaxFrameCount);
- }
- {
- SCOPED_TRACE("Underrun");
- scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, kMaxFrameCount + 1);
- EXPECT_FALSE(fifo.Consume(bus.get(), bus->frames()));
- EXPECT_EQ(fifo.frames_in_fifo(), kMaxFrameCount);
+ fifo.Consume(bus.get(), 0, bus->frames());
+ EXPECT_EQ(fifo.frames(), 0);
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), kMaxFrameCount);
}
}
-// Verify that the frames_in_fifo() method of the FIFO works as intended while
+// Verify that the frames() method of the FIFO works as intended while
// appending and removing audio bus elements to/from the FIFO.
TEST_F(AudioFifoTest, FramesInFifo) {
static const int kChannels = 2;
@@ -107,25 +93,19 @@ TEST_F(AudioFifoTest, FramesInFifo) {
// one audio frame each time.
scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, 1);
int n = 0;
- while (fifo.frames_in_fifo() < kMaxFrameCount) {
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), ++n);
+ while (fifo.frames() < kMaxFrameCount) {
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), ++n);
}
-
- // Ensure that we can't append more data when the FIFO is full.
- EXPECT_EQ(fifo.frames_in_fifo(), kMaxFrameCount);
- EXPECT_FALSE(fifo.Push(bus.get()));
+ EXPECT_EQ(fifo.frames(), kMaxFrameCount);
// Empty the FIFO and verify that the size decreases as it should.
// Reduce the size of the FIFO by one frame each time.
- while (fifo.frames_in_fifo() > 0) {
- EXPECT_TRUE(fifo.Consume(bus.get(), bus->frames()));
- EXPECT_EQ(fifo.frames_in_fifo(), --n);
+ while (fifo.frames() > 0) {
+ fifo.Consume(bus.get(), 0, bus->frames());
+ EXPECT_EQ(fifo.frames(), --n);
}
-
- // Ensure that we can't remove more data when the FIFO is empty.
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
- EXPECT_FALSE(fifo.Consume(bus.get(), bus->frames()));
+ EXPECT_EQ(fifo.frames(), 0);
// Verify that a steady-state size of #frames in the FIFO is maintained
// during a sequence of Push/Consume calls which involves wrapping. We ensure
@@ -134,12 +114,12 @@ TEST_F(AudioFifoTest, FramesInFifo) {
scoped_ptr<AudioBus> bus2 =
AudioBus::Create(kChannels, (kMaxFrameCount / 4) - 1);
const int frames_in_fifo = bus2->frames();
- EXPECT_TRUE(fifo.Push(bus2.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), frames_in_fifo);
+ fifo.Push(bus2.get());
+ EXPECT_EQ(fifo.frames(), frames_in_fifo);
for (int n = 0; n < kMaxFrameCount; ++n) {
- EXPECT_TRUE(fifo.Push(bus2.get()));
- EXPECT_TRUE(fifo.Consume(bus2.get(), frames_in_fifo));
- EXPECT_EQ(fifo.frames_in_fifo(), frames_in_fifo);
+ fifo.Push(bus2.get());
+ fifo.Consume(bus2.get(), 0, frames_in_fifo);
+ EXPECT_EQ(fifo.frames(), frames_in_fifo);
}
}
@@ -153,23 +133,23 @@ TEST_F(AudioFifoTest, VerifyDataValues) {
AudioFifo fifo(kChannels, kFifoFrameCount);
scoped_ptr<AudioBus> bus = AudioBus::Create(kChannels, kFrameCount);
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
+ EXPECT_EQ(fifo.frames(), 0);
EXPECT_EQ(bus->frames(), kFrameCount);
// Start by filling up the FIFO with audio frames. The first audio frame
// will contain all 1's, the second all 2's etc. All channels contain the
// same value.
int value = 1;
- while (fifo.frames_in_fifo() < kFifoFrameCount) {
+ while (fifo.frames() < kFifoFrameCount) {
for (int j = 0; j < bus->channels(); ++j)
std::fill(bus->channel(j), bus->channel(j) + bus->frames(), value);
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), bus->frames() * value);
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), bus->frames() * value);
++value;
}
// FIFO should be full now.
- EXPECT_EQ(fifo.frames_in_fifo(), kFifoFrameCount);
+ EXPECT_EQ(fifo.frames(), kFifoFrameCount);
// Consume all audio frames in the FIFO and verify that the stored values
// are correct. In this example, we shall read out: 1, 2, 3, 4, 5 in that
@@ -178,8 +158,8 @@ TEST_F(AudioFifoTest, VerifyDataValues) {
value = 1;
int n = 1;
const int frames_to_consume = bus->frames() / 2;
- while (fifo.frames_in_fifo() > 0) {
- EXPECT_TRUE(fifo.Consume(bus.get(), frames_to_consume));
+ while (fifo.frames() > 0) {
+ fifo.Consume(bus.get(), 0, frames_to_consume);
for (int j = 0; j < bus->channels(); ++j)
VerifyValue(bus->channel(j), frames_to_consume, value);
if (n++ % 2 == 0)
@@ -187,26 +167,26 @@ TEST_F(AudioFifoTest, VerifyDataValues) {
}
// FIFO should be empty now.
- EXPECT_EQ(fifo.frames_in_fifo(), 0);
+ EXPECT_EQ(fifo.frames(), 0);
// Push one audio bus to the FIFO and fill it with 1's.
value = 1;
for (int j = 0; j < bus->channels(); ++j)
std::fill(bus->channel(j), bus->channel(j) + bus->frames(), value);
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), bus->frames());
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), bus->frames());
// Keep calling Consume/Push a few rounds and verify that we read out the
// correct values. The number of elements shall be fixed (kFrameCount) during
// this phase.
for (int i = 0; i < 5 * kFifoFrameCount; i++) {
- EXPECT_TRUE(fifo.Consume(bus.get(), bus->frames()));
+ fifo.Consume(bus.get(), 0, bus->frames());
for (int j = 0; j < bus->channels(); ++j) {
VerifyValue(bus->channel(j), bus->channels(), value);
std::fill(bus->channel(j), bus->channel(j) + bus->frames(), value + 1);
}
- EXPECT_TRUE(fifo.Push(bus.get()));
- EXPECT_EQ(fifo.frames_in_fifo(), bus->frames());
+ fifo.Push(bus.get());
+ EXPECT_EQ(fifo.frames(), bus->frames());
++value;
}
}
« no previous file with comments | « media/base/audio_fifo.cc ('k') | media/base/audio_pull_fifo.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698