diff options
author | hclam@chromium.org <hclam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-02-09 20:56:17 +0000 |
---|---|---|
committer | hclam@chromium.org <hclam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-02-09 20:56:17 +0000 |
commit | 2559e45a158b52215534b09c4e0be13f7e3b275a (patch) | |
tree | 6e9c4ee13ff765a46a0f85d4426dd4aec101dd3a /media | |
parent | a4bbdf7a9e474e5d00d35c4abdc36f8e0ee0b72a (diff) | |
download | chromium_src-2559e45a158b52215534b09c4e0be13f7e3b275a.zip chromium_src-2559e45a158b52215534b09c4e0be13f7e3b275a.tar.gz chromium_src-2559e45a158b52215534b09c4e0be13f7e3b275a.tar.bz2 |
Unit test for OmxInputBuffer
TEST=media_unittest --gtest_filter=OmxInputBuffer.*
BUG=32753
Review URL: http://codereview.chromium.org/580012
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@38502 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'media')
-rw-r--r-- | media/media.gyp | 1 | ||||
-rw-r--r-- | media/omx/omx_input_buffer_unittest.cc | 67 |
2 files changed, 68 insertions, 0 deletions
diff --git a/media/media.gyp b/media/media.gyp index 935a0f4..33481b5 100644 --- a/media/media.gyp +++ b/media/media.gyp @@ -215,6 +215,7 @@ 'filters/file_data_source_unittest.cc', 'filters/video_decoder_impl_unittest.cc', 'filters/video_renderer_base_unittest.cc', + 'omx/omx_input_buffer_unittest.cc', ], 'conditions': [ ['OS=="linux" or OS=="freebsd"', { diff --git a/media/omx/omx_input_buffer_unittest.cc b/media/omx/omx_input_buffer_unittest.cc new file mode 100644 index 0000000..50a2302 --- /dev/null +++ b/media/omx/omx_input_buffer_unittest.cc @@ -0,0 +1,67 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "media/omx/omx_input_buffer.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace { + +const int kSize = 256; + +void GenerateData(uint8** data, int size) { + *data = new uint8[size]; + for (int i = 0; i < size; ++i) { + (*data)[i] = static_cast<uint8>(i); + } +} + +bool VerifyData(uint8* data, int size, int offset) { + bool data_mismatch = false; + for (int i = 0; i < size; ++i) { + if (data[i] != static_cast<uint8>(offset + i)) { + data_mismatch = true; + break; + } + } + return !data_mismatch; +} + +} // namespace + +namespace media { + +TEST(OmxInputBufferTest, Read) { + scoped_array<uint8> read_buffer(new uint8[kSize]); + uint8* data; + GenerateData(&data, kSize); + scoped_refptr<OmxInputBuffer> buffer(new OmxInputBuffer(data, kSize)); + EXPECT_FALSE(buffer->Used()); + + // Perform the first read. + EXPECT_EQ(10, buffer->Read(read_buffer.get(), 10)); + EXPECT_FALSE(buffer->Used()); + EXPECT_TRUE(VerifyData(read_buffer.get(), 10, 0)); + + // Perform the second read. + EXPECT_EQ(10, buffer->Read(read_buffer.get(), 10)); + EXPECT_FALSE(buffer->Used()); + EXPECT_TRUE(VerifyData(read_buffer.get(), 10, 10)); + + // Perform the last read. + EXPECT_EQ(kSize - 20, buffer->Read(read_buffer.get(), kSize)); + EXPECT_TRUE(buffer->Used()); + EXPECT_TRUE(VerifyData(read_buffer.get(), kSize - 20, 20)); + + // This read will return nothing. + EXPECT_EQ(0, buffer->Read(read_buffer.get(), kSize)); + EXPECT_TRUE(buffer->Used()); +} + +TEST(OmxInputBufferTest, EmptyBuffer) { + scoped_refptr<OmxInputBuffer> buffer(new OmxInputBuffer(NULL, 0)); + EXPECT_TRUE(buffer->IsEndOfStream()); + EXPECT_TRUE(buffer->Used()); +} + +} // namespace media |