Index: media/remoting/proto_utils_unittest.cc |
diff --git a/media/remoting/rpc/proto_utils_unittest.cc b/media/remoting/proto_utils_unittest.cc |
similarity index 74% |
rename from media/remoting/rpc/proto_utils_unittest.cc |
rename to media/remoting/proto_utils_unittest.cc |
index 71cba9d3fb06938799d1ebfc7d98df0ff515d019..53ab59197d8ad3a1ab9b18d6678faf5edbac584c 100644 |
--- a/media/remoting/rpc/proto_utils_unittest.cc |
+++ b/media/remoting/proto_utils_unittest.cc |
@@ -2,7 +2,7 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "media/remoting/rpc/proto_utils.h" |
+#include "media/remoting/proto_utils.h" |
#include <memory> |
#include <string> |
@@ -19,7 +19,7 @@ |
#include "media/base/demuxer_stream.h" |
#include "media/base/eme_constants.h" |
#include "media/base/video_decoder_config.h" |
-#include "media/remoting/remoting_rpc_message.pb.h" |
+#include "media/remoting/rpc.pb.h" |
#include "testing/gmock/include/gmock/gmock.h" |
#include "testing/gtest/include/gtest/gtest.h" |
@@ -37,14 +37,13 @@ class ProtoUtilsTest : public testing::Test { |
TEST_F(ProtoUtilsTest, PassEOSDecoderBuffer) { |
// 1. To DecoderBuffer |
- scoped_refptr<::media::DecoderBuffer> input_buffer = |
- ::media::DecoderBuffer::CreateEOSBuffer(); |
+ scoped_refptr<DecoderBuffer> input_buffer = DecoderBuffer::CreateEOSBuffer(); |
// 2. To Byte Array |
- std::vector<uint8_t> data = DecoderBufferToByteArray(input_buffer); |
+ std::vector<uint8_t> data = DecoderBufferToByteArray(*input_buffer); |
// 3. To DecoderBuffer |
- scoped_refptr<::media::DecoderBuffer> output_buffer = |
+ scoped_refptr<DecoderBuffer> output_buffer = |
ByteArrayToDecoderBuffer(data.data(), data.size()); |
DCHECK(output_buffer); |
@@ -71,17 +70,16 @@ TEST_F(ProtoUtilsTest, PassValidDecoderBuffer) { |
base::TimeDelta pts = base::TimeDelta::FromMilliseconds(5); |
// 1. To DecoderBuffer |
- scoped_refptr<::media::DecoderBuffer> input_buffer = |
- ::media::DecoderBuffer::CopyFrom(buffer, buffer_size, side_buffer, |
- side_buffer_size); |
+ scoped_refptr<DecoderBuffer> input_buffer = DecoderBuffer::CopyFrom( |
+ buffer, buffer_size, side_buffer, side_buffer_size); |
input_buffer->set_timestamp(pts); |
input_buffer->set_is_key_frame(true); |
// 2. To Byte Array |
- std::vector<uint8_t> data = DecoderBufferToByteArray(input_buffer); |
+ std::vector<uint8_t> data = DecoderBufferToByteArray(*input_buffer); |
// 3. To DecoderBuffer |
- scoped_refptr<::media::DecoderBuffer> output_buffer = |
+ scoped_refptr<DecoderBuffer> output_buffer = |
ByteArrayToDecoderBuffer(data.data(), data.size()); |
DCHECK(output_buffer); |
@@ -120,6 +118,39 @@ TEST_F(ProtoUtilsTest, AudioDecoderConfigConversionTest) { |
ASSERT_TRUE(audio_config.Matches(audio_output_config)); |
} |
+TEST_F(ProtoUtilsTest, PipelineStatisticsConversion) { |
+ PipelineStatistics original; |
+ // Note: Fill the structure with non-zero bytes to ensure this test is |
+ // initializing *all* fields. |
+ memset(&original, 0xcd, sizeof(original)); |
+ original.audio_bytes_decoded = 123; |
+ original.video_bytes_decoded = 456; |
+ original.video_frames_decoded = 789; |
+ original.video_frames_dropped = 21; |
+ original.audio_memory_usage = 32; |
+ original.video_memory_usage = 43; |
+ original.video_keyframe_distance_average = base::TimeDelta::Max(); |
+ |
+ // There is no convert-to-proto function, so just do that here. |
+ pb::PipelineStatistics pb_stats; |
+ pb_stats.set_audio_bytes_decoded(original.audio_bytes_decoded); |
+ pb_stats.set_video_bytes_decoded(original.video_bytes_decoded); |
+ pb_stats.set_video_frames_decoded(original.video_frames_decoded); |
+ pb_stats.set_video_frames_dropped(original.video_frames_dropped); |
+ pb_stats.set_audio_memory_usage(original.audio_memory_usage); |
+ pb_stats.set_video_memory_usage(original.video_memory_usage); |
+ |
+ PipelineStatistics converted; |
+ memset(&converted, ~0xcd, sizeof(converted)); // See note above. |
+ ConvertProtoToPipelineStatistics(pb_stats, &converted); |
+ |
+ // If this fails, did media::PipelineStatistics add/change fields that are not |
+ // being set by media::remoting::ConvertProtoToPipelineStatistics()? |
+ EXPECT_EQ(0, memcmp(&original, &converted, sizeof(converted))); |
+} |
+ |
+// TODO(miu): Tests for all other conversion functions. |
+ |
TEST_F(ProtoUtilsTest, CdmPromiseResultConversion) { |
CdmPromiseResult success_result = CdmPromiseResult::SuccessResult(); |