// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <stdint.h>
#include "media/parsers/h266_parser.h"
#include "media/parsers/h266_poc.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace media {
class H266POCTest : public testing::Test {
public:
H266POCTest() : sps_(), pps_(), vps_(), ph_(), slice_hdr_(), h266_poc_() {}
H266POCTest(const H266POCTest&) = delete;
H266POCTest& operator=(const H266POCTest&) = delete;
protected:
void ComputePOC() {
poc_ = h266_poc_.ComputePicOrderCnt(&sps_, &pps_, &vps_, &ph_, slice_hdr_);
}
int32_t poc_;
H266SPS sps_;
H266PPS pps_;
H266VPS vps_;
H266PictureHeader ph_;
H266SliceHeader slice_hdr_;
H266POC h266_poc_;
};
TEST_F(H266POCTest, PicOrderCnt) {
sps_.sps_log2_max_pic_order_cnt_lsb_minus4 = 7;
vps_.vps_video_parameter_set_id = 0;
vps_.vps_max_layers_minus1 = 0;
vps_.vps_max_sublayers_minus1 = 0;
vps_.vps_independent_layer_flag[0] = 1;
vps_.vps_layer_id[0] = 0;
vps_.general_layer_idx[0] = 0;
vps_.vps_ols_ptl_idx[0] = 0;
vps_.vps_ptl_max_tid[0] = 0;
slice_hdr_.temporal_id = 0;
slice_hdr_.nuh_layer_id = 0;
// Initial I frame with POC 0.
slice_hdr_.nal_unit_type = H266NALU::kIDRNoLeadingPicture;
ph_.ph_pic_order_cnt_lsb = 0;
ComputePOC();
ASSERT_EQ(0, poc_);
// P frame with POC lsb 4.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 4;
ComputePOC();
ASSERT_EQ(4, poc_);
// B frame with POC lsb 2.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 2;
ComputePOC();
ASSERT_EQ(2, poc_);
// B frame with POC lsb 1.
slice_hdr_.nal_unit_type = H266NALU::kSTSA;
ph_.ph_pic_order_cnt_lsb = 1;
ComputePOC();
ASSERT_EQ(1, poc_);
// B frame with POC lsb 3.
slice_hdr_.nal_unit_type = H266NALU::kSTSA;
ph_.ph_pic_order_cnt_lsb = 3;
ComputePOC();
ASSERT_EQ(3, poc_);
// P frame with POC lsb 8.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 8;
ComputePOC();
ASSERT_EQ(8, poc_);
// B Ref frame with POC lsb 6.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 6;
ComputePOC();
ASSERT_EQ(6, poc_);
// B frame with POC lsb 5.
slice_hdr_.nal_unit_type = H266NALU::kSTSA;
ph_.ph_pic_order_cnt_lsb = 5;
ComputePOC();
ASSERT_EQ(5, poc_);
// B frame with POC lsb 7.
slice_hdr_.nal_unit_type = H266NALU::kSTSA;
ph_.ph_pic_order_cnt_lsb = 7;
ComputePOC();
ASSERT_EQ(7, poc_);
// P frame with POC lsb 12.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 12;
ComputePOC();
ASSERT_EQ(12, poc_);
// B frame with POC lsb 10.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 10;
ComputePOC();
ASSERT_EQ(10, poc_);
// B frame with POC lsb 9.
slice_hdr_.nal_unit_type = H266NALU::kSTSA;
ph_.ph_pic_order_cnt_lsb = 9;
ComputePOC();
ASSERT_EQ(9, poc_);
// B frame with POC lsb 11.
slice_hdr_.nal_unit_type = H266NALU::kSTSA;
ph_.ph_pic_order_cnt_lsb = 11;
ComputePOC();
ASSERT_EQ(11, poc_);
// P frame with POC lsb 16.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 16;
ComputePOC();
ASSERT_EQ(16, poc_);
// B frame with POC lsb 14.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 14;
ComputePOC();
ASSERT_EQ(14, poc_);
// B frame with POC lsb 13.
slice_hdr_.nal_unit_type = H266NALU::kSTSA;
ph_.ph_pic_order_cnt_lsb = 13;
ComputePOC();
ASSERT_EQ(13, poc_);
// B frame with POC lsb 15.
slice_hdr_.nal_unit_type = H266NALU::kSTSA;
ph_.ph_pic_order_cnt_lsb = 15;
ComputePOC();
ASSERT_EQ(15, poc_);
}
TEST_F(H266POCTest, PicOrderCntInOrder) {
sps_.sps_log2_max_pic_order_cnt_lsb_minus4 = 7;
vps_.vps_video_parameter_set_id = 0;
vps_.vps_max_layers_minus1 = 0;
vps_.vps_max_sublayers_minus1 = 0;
vps_.vps_independent_layer_flag[0] = 1;
vps_.vps_layer_id[0] = 0;
vps_.general_layer_idx[0] = 0;
vps_.vps_ols_ptl_idx[0] = 0;
vps_.vps_ptl_max_tid[0] = 0;
slice_hdr_.temporal_id = 0;
slice_hdr_.nuh_layer_id = 0;
// Initial I frame with POC 0.
slice_hdr_.nal_unit_type = H266NALU::kIDRWithRADL;
ph_.ph_pic_order_cnt_lsb = 0;
ComputePOC();
ASSERT_EQ(0, poc_);
// P frame with POC lsb 1.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 1;
ComputePOC();
ASSERT_EQ(1, poc_);
// P frame with POC lsb 2.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 2;
ComputePOC();
ASSERT_EQ(2, poc_);
// P frame with POC lsb 3.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 3;
ComputePOC();
ASSERT_EQ(3, poc_);
// P frame with POC lsb 4.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 4;
ComputePOC();
ASSERT_EQ(4, poc_);
// P frame with POC lsb 5.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 5;
ComputePOC();
ASSERT_EQ(5, poc_);
// P frame with POC lsb 6.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 6;
ComputePOC();
ASSERT_EQ(6, poc_);
// P frame with POC lsb 7.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 7;
ComputePOC();
ASSERT_EQ(7, poc_);
// P frame with POC lsb 8.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 8;
ComputePOC();
ASSERT_EQ(8, poc_);
// P frame with POC lsb 9.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 9;
ComputePOC();
ASSERT_EQ(9, poc_);
// P frame with POC lsb 10.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 10;
ComputePOC();
ASSERT_EQ(10, poc_);
// P frame with POC lsb 11.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 11;
ComputePOC();
ASSERT_EQ(11, poc_);
// P frame with POC lsb 12.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 12;
ComputePOC();
ASSERT_EQ(12, poc_);
// P frame with POC lsb 13.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 13;
ComputePOC();
ASSERT_EQ(13, poc_);
// P frame with POC lsb 14.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 14;
ComputePOC();
ASSERT_EQ(14, poc_);
// P frame with POC lsb 15.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 15;
ComputePOC();
ASSERT_EQ(15, poc_);
// P frame with POC lsb 16.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 16;
ComputePOC();
ASSERT_EQ(16, poc_);
// P frame with POC lsb 17.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 17;
ComputePOC();
ASSERT_EQ(17, poc_);
// P frame with POC lsb 18.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 18;
ComputePOC();
ASSERT_EQ(18, poc_);
// P frame with POC lsb 19.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 19;
ComputePOC();
ASSERT_EQ(19, poc_);
// P frame with POC lsb 20.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 20;
ComputePOC();
ASSERT_EQ(20, poc_);
// P frame with POC lsb 21.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 21;
ComputePOC();
ASSERT_EQ(21, poc_);
// P frame with POC lsb 22.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 22;
ComputePOC();
ASSERT_EQ(22, poc_);
// P frame with POC lsb 23.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 23;
ComputePOC();
ASSERT_EQ(23, poc_);
// P frame with POC lsb 24.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 24;
ComputePOC();
ASSERT_EQ(24, poc_);
// P frame with POC lsb 25.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 25;
ComputePOC();
ASSERT_EQ(25, poc_);
// P frame with POC lsb 26.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 26;
ComputePOC();
ASSERT_EQ(26, poc_);
// P frame with POC lsb 27.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 27;
ComputePOC();
ASSERT_EQ(27, poc_);
// P frame with POC lsb 28.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 28;
ComputePOC();
ASSERT_EQ(28, poc_);
// P frame with POC lsb 29.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 29;
ComputePOC();
ASSERT_EQ(29, poc_);
// I frame with POC 0.
slice_hdr_.nal_unit_type = H266NALU::kIDRWithRADL;
ph_.ph_pic_order_cnt_lsb = 0;
ComputePOC();
ASSERT_EQ(0, poc_);
// P frame with POC lsb 1.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 1;
ComputePOC();
ASSERT_EQ(1, poc_);
// P frame with POC lsb 2.
slice_hdr_.nal_unit_type = H266NALU::kTrail;
ph_.ph_pic_order_cnt_lsb = 2;
ComputePOC();
ASSERT_EQ(2, poc_);
}
} // namespace media