| Index: media/base/audio_buffer_unittest.cc | 
| diff --git a/media/base/audio_buffer_unittest.cc b/media/base/audio_buffer_unittest.cc | 
| index a897d8fa84957ea9a9eee583e4f23101fa6c64b7..e60d7a00a3fa45c4305bae6ad5649216cb6ec772 100644 | 
| --- a/media/base/audio_buffer_unittest.cc | 
| +++ b/media/base/audio_buffer_unittest.cc | 
| @@ -434,4 +434,51 @@ TEST(AudioBufferTest, TrimRangeInterleaved) { | 
| TrimRangeTest(kSampleFormatF32); | 
| } | 
|  | 
| +TEST(AudioBufferTest, AudioBufferMemoryPool) { | 
| +  scoped_refptr<AudioBufferMemoryPool> pool(new AudioBufferMemoryPool()); | 
| +  EXPECT_EQ(0u, pool->get_pool_size_for_testing()); | 
| + | 
| +  const ChannelLayout kChannelLayout = CHANNEL_LAYOUT_MONO; | 
| +  scoped_refptr<AudioBuffer> buffer = MakeAudioBuffer<uint8_t>( | 
| +      kSampleFormatU8, kChannelLayout, | 
| +      ChannelLayoutToChannelCount(kChannelLayout), kSampleRate, 1, 1, | 
| +      kSampleRate / 100, base::TimeDelta()); | 
| + | 
| +  // Creating and returning a buffer should increase pool size. | 
| +  scoped_refptr<AudioBuffer> b1 = AudioBuffer::CopyFrom( | 
| +      kSampleFormatU8, buffer->channel_layout(), buffer->channel_count(), | 
| +      buffer->sample_rate(), buffer->frame_count(), &buffer->channel_data()[0], | 
| +      buffer->timestamp(), pool); | 
| +  EXPECT_EQ(0u, pool->get_pool_size_for_testing()); | 
| +  b1 = nullptr; | 
| +  EXPECT_EQ(1u, pool->get_pool_size_for_testing()); | 
| + | 
| +  // Even (especially) when used with CreateBuffer. | 
| +  b1 = AudioBuffer::CreateBuffer(kSampleFormatU8, buffer->channel_layout(), | 
| +                                 buffer->channel_count(), buffer->sample_rate(), | 
| +                                 buffer->frame_count(), pool); | 
| +  EXPECT_EQ(0u, pool->get_pool_size_for_testing()); | 
| +  scoped_refptr<AudioBuffer> b2 = AudioBuffer::CreateBuffer( | 
| +      kSampleFormatU8, buffer->channel_layout(), buffer->channel_count(), | 
| +      buffer->sample_rate(), buffer->frame_count(), pool); | 
| +  EXPECT_EQ(0u, pool->get_pool_size_for_testing()); | 
| +  b2 = nullptr; | 
| +  EXPECT_EQ(1u, pool->get_pool_size_for_testing()); | 
| +  b1 = nullptr; | 
| +  EXPECT_EQ(2u, pool->get_pool_size_for_testing()); | 
| + | 
| +  // A buffer of a different size should not reuse the buffer and drain pool. | 
| +  b2 = AudioBuffer::CreateBuffer(kSampleFormatU8, buffer->channel_layout(), | 
| +                                 buffer->channel_count(), buffer->sample_rate(), | 
| +                                 buffer->frame_count() / 2, pool); | 
| +  EXPECT_EQ(0u, pool->get_pool_size_for_testing()); | 
| + | 
| +  // Mark pool for destruction and ensure buffer is still valid. | 
| +  pool = nullptr; | 
| +  memset(b2->channel_data()[0], 0, b2->frame_count()); | 
| + | 
| +  // Destruct final frame after pool; hope nothing explodes. | 
| +  b2 = nullptr; | 
| +} | 
| + | 
| }  // namespace media | 
|  |