OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/files/memory_mapped_file.h" | 5 #include "base/files/memory_mapped_file.h" |
6 #include "base/logging.h" | 6 #include "base/logging.h" |
7 #include "media/base/test_data_util.h" | 7 #include "media/base/test_data_util.h" |
8 #include "media/filters/ivf_parser.h" | 8 #include "media/filters/ivf_parser.h" |
9 #include "media/filters/vp9_parser.h" | 9 #include "media/filters/vp9_parser.h" |
10 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 << file_path.MaybeAsASCII(); | 21 << file_path.MaybeAsASCII(); |
22 | 22 |
23 IvfFileHeader ivf_file_header; | 23 IvfFileHeader ivf_file_header; |
24 ASSERT_TRUE(ivf_parser_.Initialize(stream_->data(), stream_->length(), | 24 ASSERT_TRUE(ivf_parser_.Initialize(stream_->data(), stream_->length(), |
25 &ivf_file_header)); | 25 &ivf_file_header)); |
26 ASSERT_EQ(ivf_file_header.fourcc, 0x30395056u); // VP90 | 26 ASSERT_EQ(ivf_file_header.fourcc, 0x30395056u); // VP90 |
27 } | 27 } |
28 | 28 |
29 void TearDown() override { stream_.reset(); } | 29 void TearDown() override { stream_.reset(); } |
30 | 30 |
| 31 bool ParseNextFrame(struct Vp9FrameHeader* frame_hdr); |
| 32 |
| 33 const Vp9Segmentation& GetSegmentation() const { |
| 34 return vp9_parser_.GetSegmentation(); |
| 35 } |
| 36 |
| 37 const Vp9LoopFilter& GetLoopFilter() const { |
| 38 return vp9_parser_.GetLoopFilter(); |
| 39 } |
| 40 |
31 IvfParser ivf_parser_; | 41 IvfParser ivf_parser_; |
32 scoped_ptr<base::MemoryMappedFile> stream_; | 42 scoped_ptr<base::MemoryMappedFile> stream_; |
| 43 |
| 44 Vp9Parser vp9_parser_; |
33 }; | 45 }; |
34 | 46 |
| 47 bool Vp9ParserTest::ParseNextFrame(Vp9FrameHeader* fhdr) { |
| 48 while (1) { |
| 49 Vp9Parser::Result res = vp9_parser_.ParseNextFrame(fhdr); |
| 50 if (res == Vp9Parser::kEOStream) { |
| 51 IvfFrameHeader ivf_frame_header; |
| 52 const uint8_t* ivf_payload; |
| 53 |
| 54 if (!ivf_parser_.ParseNextFrame(&ivf_frame_header, &ivf_payload)) |
| 55 return false; |
| 56 |
| 57 vp9_parser_.SetStream(ivf_payload, ivf_frame_header.frame_size); |
| 58 continue; |
| 59 } |
| 60 |
| 61 return res == Vp9Parser::kOk; |
| 62 } |
| 63 } |
| 64 |
35 TEST_F(Vp9ParserTest, StreamFileParsing) { | 65 TEST_F(Vp9ParserTest, StreamFileParsing) { |
36 // Number of frames in the test stream to be parsed. | 66 // Number of frames in the test stream to be parsed. |
37 const int num_frames = 250; | 67 const int num_frames = 250; |
| 68 int num_parsed_frames = 0; |
38 | 69 |
39 Vp9Parser vp9_parser; | 70 while (num_parsed_frames < num_frames) { |
40 IvfFrameHeader ivf_frame_header; | 71 Vp9FrameHeader fhdr; |
41 int num_parsed_frames = 0; | 72 if (!ParseNextFrame(&fhdr)) |
42 const uint8_t* ivf_payload; | 73 break; |
43 | 74 |
44 // Parse until the end of stream/unsupported stream/error in stream is found. | |
45 while (ivf_parser_.ParseNextFrame(&ivf_frame_header, &ivf_payload)) { | |
46 Vp9FrameHeader fhdr; | |
47 | |
48 ASSERT_TRUE( | |
49 vp9_parser.ParseFrame(ivf_payload, ivf_frame_header.frame_size, &fhdr)); | |
50 ++num_parsed_frames; | 75 ++num_parsed_frames; |
51 } | 76 } |
52 | 77 |
53 DVLOG(1) << "Number of successfully parsed frames before EOS: " | 78 DVLOG(1) << "Number of successfully parsed frames before EOS: " |
54 << num_parsed_frames; | 79 << num_parsed_frames; |
55 | 80 |
56 EXPECT_EQ(num_frames, num_parsed_frames); | 81 EXPECT_EQ(num_frames, num_parsed_frames); |
57 } | 82 } |
58 | 83 |
59 TEST_F(Vp9ParserTest, VerifyFirstFrame) { | 84 TEST_F(Vp9ParserTest, VerifyFirstFrame) { |
60 Vp9Parser vp9_parser; | |
61 IvfFrameHeader ivf_frame_header; | |
62 const uint8_t* ivf_payload; | |
63 | |
64 ASSERT_TRUE(ivf_parser_.ParseNextFrame(&ivf_frame_header, &ivf_payload)); | |
65 Vp9FrameHeader fhdr; | 85 Vp9FrameHeader fhdr; |
66 | 86 |
67 ASSERT_TRUE( | 87 ASSERT_TRUE(ParseNextFrame(&fhdr)); |
68 vp9_parser.ParseFrame(ivf_payload, ivf_frame_header.frame_size, &fhdr)); | |
69 | 88 |
70 EXPECT_EQ(0, fhdr.profile); | 89 EXPECT_EQ(0, fhdr.profile); |
71 EXPECT_FALSE(fhdr.show_existing_frame); | 90 EXPECT_FALSE(fhdr.show_existing_frame); |
72 EXPECT_EQ(Vp9FrameHeader::KEYFRAME, fhdr.frame_type); | 91 EXPECT_EQ(Vp9FrameHeader::KEYFRAME, fhdr.frame_type); |
73 EXPECT_TRUE(fhdr.show_frame); | 92 EXPECT_TRUE(fhdr.show_frame); |
74 EXPECT_FALSE(fhdr.error_resilient_mode); | 93 EXPECT_FALSE(fhdr.error_resilient_mode); |
75 | 94 |
76 EXPECT_EQ(8, fhdr.bit_depth); | 95 EXPECT_EQ(8, fhdr.bit_depth); |
77 EXPECT_EQ(Vp9ColorSpace::UNKNOWN, fhdr.color_space); | 96 EXPECT_EQ(Vp9ColorSpace::UNKNOWN, fhdr.color_space); |
78 EXPECT_FALSE(fhdr.yuv_range); | 97 EXPECT_FALSE(fhdr.yuv_range); |
79 EXPECT_EQ(1, fhdr.subsampling_x); | 98 EXPECT_EQ(1, fhdr.subsampling_x); |
80 EXPECT_EQ(1, fhdr.subsampling_y); | 99 EXPECT_EQ(1, fhdr.subsampling_y); |
81 | 100 |
82 EXPECT_EQ(320u, fhdr.width); | 101 EXPECT_EQ(320u, fhdr.width); |
83 EXPECT_EQ(240u, fhdr.height); | 102 EXPECT_EQ(240u, fhdr.height); |
84 EXPECT_EQ(320u, fhdr.display_width); | 103 EXPECT_EQ(320u, fhdr.display_width); |
85 EXPECT_EQ(240u, fhdr.display_height); | 104 EXPECT_EQ(240u, fhdr.display_height); |
86 | 105 |
87 EXPECT_TRUE(fhdr.refresh_frame_context); | 106 EXPECT_TRUE(fhdr.refresh_frame_context); |
88 EXPECT_TRUE(fhdr.frame_parallel_decoding_mode); | 107 EXPECT_TRUE(fhdr.frame_parallel_decoding_mode); |
89 EXPECT_EQ(0, fhdr.frame_context_idx); | 108 EXPECT_EQ(0, fhdr.frame_context_idx); |
90 | 109 |
91 EXPECT_EQ(9, fhdr.loop_filter.filter_level); | 110 const Vp9LoopFilter& lf = GetLoopFilter(); |
92 EXPECT_EQ(0, fhdr.loop_filter.sharpness_level); | 111 EXPECT_EQ(9, lf.filter_level); |
93 | 112 EXPECT_EQ(0, lf.sharpness_level); |
94 const Vp9LoopFilter& lf = fhdr.loop_filter; | |
95 EXPECT_TRUE(lf.mode_ref_delta_enabled); | 113 EXPECT_TRUE(lf.mode_ref_delta_enabled); |
96 EXPECT_TRUE(lf.mode_ref_delta_update); | 114 EXPECT_TRUE(lf.mode_ref_delta_update); |
97 EXPECT_TRUE(lf.update_ref_deltas[0]); | 115 EXPECT_TRUE(lf.update_ref_deltas[0]); |
98 EXPECT_EQ(1, lf.ref_deltas[0]); | 116 EXPECT_EQ(1, lf.ref_deltas[0]); |
99 EXPECT_EQ(-1, lf.ref_deltas[2]); | 117 EXPECT_EQ(-1, lf.ref_deltas[2]); |
100 EXPECT_EQ(-1, lf.ref_deltas[3]); | 118 EXPECT_EQ(-1, lf.ref_deltas[3]); |
101 | 119 |
102 const Vp9QuantizationParams& qp = fhdr.quant_params; | 120 const Vp9QuantizationParams& qp = fhdr.quant_params; |
103 EXPECT_EQ(65, qp.base_qindex); | 121 EXPECT_EQ(65, qp.base_qindex); |
104 EXPECT_FALSE(qp.y_dc_delta); | 122 EXPECT_FALSE(qp.y_dc_delta); |
105 EXPECT_FALSE(qp.uv_dc_delta); | 123 EXPECT_FALSE(qp.uv_dc_delta); |
106 EXPECT_FALSE(qp.uv_ac_delta); | 124 EXPECT_FALSE(qp.uv_ac_delta); |
107 EXPECT_FALSE(qp.IsLossless()); | 125 EXPECT_FALSE(qp.IsLossless()); |
108 | 126 |
109 const Vp9Segmentation& seg = fhdr.segment; | 127 const Vp9Segmentation& seg = GetSegmentation(); |
110 EXPECT_FALSE(seg.enabled); | 128 EXPECT_FALSE(seg.enabled); |
111 | 129 |
112 EXPECT_EQ(0, fhdr.log2_tile_cols); | 130 EXPECT_EQ(0, fhdr.log2_tile_cols); |
113 EXPECT_EQ(0, fhdr.log2_tile_rows); | 131 EXPECT_EQ(0, fhdr.log2_tile_rows); |
114 | 132 |
115 EXPECT_EQ(120u, fhdr.first_partition_size); | 133 EXPECT_EQ(120u, fhdr.first_partition_size); |
116 EXPECT_EQ(18u, fhdr.uncompressed_header_size); | 134 EXPECT_EQ(18u, fhdr.uncompressed_header_size); |
117 } | 135 } |
118 | 136 |
119 TEST_F(Vp9ParserTest, VerifyInterFrame) { | 137 TEST_F(Vp9ParserTest, VerifyInterFrame) { |
120 Vp9Parser vp9_parser; | |
121 Vp9FrameHeader fhdr; | 138 Vp9FrameHeader fhdr; |
122 | 139 |
123 // To verify the second frame. | 140 // To verify the second frame. |
124 for (int i = 0; i < 2; i++) { | 141 for (int i = 0; i < 2; i++) |
125 IvfFrameHeader ivf_frame_header; | 142 ASSERT_TRUE(ParseNextFrame(&fhdr)); |
126 const uint8_t* ivf_payload; | |
127 ASSERT_TRUE(ivf_parser_.ParseNextFrame(&ivf_frame_header, &ivf_payload)); | |
128 ASSERT_TRUE( | |
129 vp9_parser.ParseFrame(ivf_payload, ivf_frame_header.frame_size, &fhdr)); | |
130 } | |
131 | 143 |
132 EXPECT_EQ(Vp9FrameHeader::INTERFRAME, fhdr.frame_type); | 144 EXPECT_EQ(Vp9FrameHeader::INTERFRAME, fhdr.frame_type); |
133 EXPECT_FALSE(fhdr.show_frame); | 145 EXPECT_FALSE(fhdr.show_frame); |
134 EXPECT_FALSE(fhdr.intra_only); | 146 EXPECT_FALSE(fhdr.intra_only); |
135 EXPECT_FALSE(fhdr.reset_context); | 147 EXPECT_FALSE(fhdr.reset_context); |
136 EXPECT_TRUE(fhdr.refresh_flag[5]); | 148 EXPECT_TRUE(fhdr.RefreshFlag(2)); |
137 EXPECT_EQ(0, fhdr.frame_refs[0]); | 149 EXPECT_EQ(0, fhdr.frame_refs[0]); |
138 EXPECT_EQ(1, fhdr.frame_refs[1]); | 150 EXPECT_EQ(1, fhdr.frame_refs[1]); |
139 EXPECT_EQ(2, fhdr.frame_refs[2]); | 151 EXPECT_EQ(2, fhdr.frame_refs[2]); |
140 EXPECT_TRUE(fhdr.allow_high_precision_mv); | 152 EXPECT_TRUE(fhdr.allow_high_precision_mv); |
141 EXPECT_EQ(Vp9InterpFilter::EIGHTTAP, fhdr.interp_filter); | 153 EXPECT_EQ(Vp9InterpFilter::EIGHTTAP, fhdr.interp_filter); |
142 | 154 |
143 EXPECT_EQ(48u, fhdr.first_partition_size); | 155 EXPECT_EQ(48u, fhdr.first_partition_size); |
144 EXPECT_EQ(11u, fhdr.uncompressed_header_size); | 156 EXPECT_EQ(11u, fhdr.uncompressed_header_size); |
145 } | 157 } |
146 | 158 |
147 } // namespace media | 159 } // namespace media |
OLD | NEW |