| Index: chromecast/media/cma/base/frame_generator_for_test.cc
|
| diff --git a/chromecast/media/cma/base/frame_generator_for_test.cc b/chromecast/media/cma/base/frame_generator_for_test.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..c03fcf8847c4543ea86ddade92d595d8e3b1bb76
|
| --- /dev/null
|
| +++ b/chromecast/media/cma/base/frame_generator_for_test.cc
|
| @@ -0,0 +1,113 @@
|
| +// Copyright 2014 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 "chromecast/media/cma/base/frame_generator_for_test.h"
|
| +
|
| +#include "chromecast/media/cma/base/decoder_buffer_adapter.h"
|
| +#include "chromecast/media/cma/base/decoder_buffer_base.h"
|
| +#include "media/base/decoder_buffer.h"
|
| +#include "media/base/decrypt_config.h"
|
| +
|
| +namespace chromecast {
|
| +namespace media {
|
| +
|
| +FrameGeneratorForTest::FrameSpec::FrameSpec()
|
| + : has_config(false),
|
| + is_eos(false),
|
| + has_decrypt_config(false),
|
| + size(0) {
|
| +}
|
| +
|
| +FrameGeneratorForTest::FrameSpec::~FrameSpec() {
|
| +}
|
| +
|
| +FrameGeneratorForTest::FrameGeneratorForTest(
|
| + const std::vector<FrameSpec> frame_specs)
|
| + : frame_specs_(frame_specs),
|
| + frame_idx_(0),
|
| + total_buffer_size_(0) {
|
| +}
|
| +
|
| +FrameGeneratorForTest::~FrameGeneratorForTest() {
|
| +}
|
| +
|
| +bool FrameGeneratorForTest::HasDecoderConfig() const {
|
| + if (frame_idx_ >= frame_specs_.size())
|
| + return false;
|
| +
|
| + return frame_specs_[frame_idx_].has_config;
|
| +}
|
| +
|
| +scoped_refptr<DecoderBufferBase> FrameGeneratorForTest::Generate() {
|
| + if (frame_idx_ >= frame_specs_.size())
|
| + return scoped_refptr<DecoderBufferBase>();
|
| +
|
| + const FrameSpec& frame_spec = frame_specs_[frame_idx_];
|
| + frame_idx_++;
|
| +
|
| + if (frame_spec.is_eos) {
|
| + return scoped_refptr<DecoderBufferBase>(
|
| + new DecoderBufferAdapter(::media::DecoderBuffer::CreateEOSBuffer()));
|
| + }
|
| +
|
| + scoped_refptr< ::media::DecoderBuffer> buffer(
|
| + new ::media::DecoderBuffer(frame_spec.size));
|
| +
|
| + // Timestamp.
|
| + buffer->set_timestamp(frame_spec.timestamp);
|
| +
|
| + // Generate the frame data.
|
| + for (size_t k = 0; k < frame_spec.size; k++) {
|
| + buffer->writable_data()[k] = total_buffer_size_ & 0xff;
|
| + total_buffer_size_++;
|
| + }
|
| +
|
| + // Generate the decrypt configuration.
|
| + if (frame_spec.has_decrypt_config) {
|
| + uint32 frame_size = buffer->data_size();
|
| + uint32 chunk_size = 1;
|
| + std::vector< ::media::SubsampleEntry> subsamples;
|
| + while (frame_size > 0) {
|
| + ::media::SubsampleEntry subsample;
|
| + subsample.clear_bytes = chunk_size;
|
| + if (subsample.clear_bytes > frame_size)
|
| + subsample.clear_bytes = frame_size;
|
| + frame_size -= subsample.clear_bytes;
|
| + chunk_size <<= 1;
|
| +
|
| + subsample.cypher_bytes = chunk_size;
|
| + if (subsample.cypher_bytes > frame_size)
|
| + subsample.cypher_bytes = frame_size;
|
| + frame_size -= subsample.cypher_bytes;
|
| + chunk_size <<= 1;
|
| +
|
| + subsamples.push_back(subsample);
|
| + }
|
| +
|
| + char key_id[] = {
|
| + 0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7,
|
| + 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf };
|
| +
|
| + char iv[] = {
|
| + 0x0, 0x2, 0x1, 0x3, 0x5, 0x4, 0x7, 0x6,
|
| + 0x9, 0x8, 0xb, 0xa, 0xd, 0xc, 0xf, 0xe };
|
| +
|
| + scoped_ptr< ::media::DecryptConfig> decrypt_config(
|
| + new ::media::DecryptConfig(
|
| + std::string(key_id, arraysize(key_id)),
|
| + std::string(iv, arraysize(iv)),
|
| + subsamples));
|
| + buffer->set_decrypt_config(decrypt_config.Pass());
|
| + }
|
| +
|
| + return scoped_refptr<DecoderBufferBase>(new DecoderBufferAdapter(buffer));
|
| +}
|
| +
|
| +size_t FrameGeneratorForTest::RemainingFrameCount() const {
|
| + size_t count = frame_specs_.size() - frame_idx_;
|
| + return count;
|
| +}
|
| +
|
| +} // namespace media
|
| +} // namespace chromecast
|
|
|