1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
media / filters / h26x_annex_b_bitstream_builder_unittest.cc [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifdef UNSAFE_BUFFERS_BUILD
// TODO(crbug.com/40285824): Remove this and convert code to safer constructs.
#pragma allow_unsafe_buffers
#endif
#include <stdint.h>
#include "base/bits.h"
#include "media/filters/h26x_annex_b_bitstream_builder.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace media {
namespace {
const uint64_t kTestPattern = 0xfedcba0987654321;
uint64_t GetDataFromBuffer(const uint8_t* ptr, uint64_t num_bits) {
uint64_t got = 0;
while (num_bits > 8) {
got |= (*ptr & 0xff);
num_bits -= 8;
got <<= (num_bits > 8 ? 8 : num_bits);
ptr++;
}
if (num_bits > 0) {
uint64_t temp = (*ptr & 0xff);
temp >>= (8 - num_bits);
got |= temp;
}
return got;
}
}
class H26xAnnexBBitstreamBuilderAppendBitsTest
: public ::testing::TestWithParam<uint64_t> {};
// TODO(posciak): More tests!
TEST_P(H26xAnnexBBitstreamBuilderAppendBitsTest, AppendAndVerifyBits) {
H26xAnnexBBitstreamBuilder b;
uint64_t num_bits = GetParam();
// TODO(posciak): Tests for >64 bits.
ASSERT_LE(num_bits, 64u);
uint64_t num_bytes = base::bits::AlignUp(num_bits, uint64_t{8}) / 8;
b.AppendBits(num_bits, kTestPattern);
b.FlushReg();
EXPECT_EQ(b.BytesInBuffer(), num_bytes);
const uint8_t* ptr = b.data();
uint64_t got = GetDataFromBuffer(ptr, num_bits);
uint64_t expected = kTestPattern;
if (num_bits < 64)
expected &= ((1ull << num_bits) - 1);
EXPECT_EQ(got, expected) << std::hex << "0x" << got << " vs 0x" << expected;
}
TEST_F(H26xAnnexBBitstreamBuilderAppendBitsTest, VerifyFlushAndBitsInBuffer) {
H26xAnnexBBitstreamBuilder b;
uint64_t num_bits = 20;
uint64_t num_bytes = base::bits::AlignUp(num_bits, uint64_t{8}) / 8;
b.AppendBits(num_bits, kTestPattern);
b.Flush();
EXPECT_EQ(b.BytesInBuffer(), num_bytes);
EXPECT_EQ(b.BitsInBuffer(), num_bits);
const uint8_t* ptr = b.data();
uint64_t got = GetDataFromBuffer(ptr, num_bits);
uint64_t expected = kTestPattern;
expected &= ((1ull << num_bits) - 1);
EXPECT_EQ(got, expected) << std::hex << "0x" << got << " vs 0x" << expected;
}
INSTANTIATE_TEST_SUITE_P(AppendNumBits,
H26xAnnexBBitstreamBuilderAppendBitsTest,
::testing::Range(static_cast<uint64_t>(1),
static_cast<uint64_t>(65)));
} // namespace media