* Copyright (C) 2023 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <iostream>
#include <cstdio>
#include <string>
#include "gtest/gtest.h"
#include "avcodec_common.h"
#include "meta/format.h"
#include "avcodec_video_encoder.h"
#include "videoenc_inner_sample.h"
#include "native_avcapability.h"
using namespace std;
using namespace OHOS;
using namespace OHOS::MediaAVCodec;
using namespace testing::ext;
namespace {
class HwEncInnerApiNdkTest : public testing::Test {
public:
static void SetUpTestCase(void);
static void TearDownTestCase(void);
void SetUp() override;
void TearDown() override;
};
constexpr uint32_t DEFAULT_WIDTH = 1920;
constexpr uint32_t DEFAULT_HEIGHT = 1080;
std::string g_codecMime = "video/avc";
std::string g_codecName = "";
OH_AVCapability *cap = nullptr;
std::shared_ptr<AVCodecVideoEncoder> venc_ = nullptr;
std::shared_ptr<VEncInnerSignal> signal_ = nullptr;
void HwEncInnerApiNdkTest::SetUpTestCase()
{
cap = OH_AVCodec_GetCapabilityByCategory(g_codecMime.c_str(), true, HARDWARE);
const char *tmpCodecName = OH_AVCapability_GetName(cap);
g_codecName = tmpCodecName;
cout << "g_codecName: " << g_codecName << endl;
}
void HwEncInnerApiNdkTest::TearDownTestCase() {}
void HwEncInnerApiNdkTest::SetUp()
{
signal_ = make_shared<VEncInnerSignal>();
}
void HwEncInnerApiNdkTest::TearDown()
{
if (venc_ != nullptr) {
venc_->Release();
venc_ = nullptr;
}
if (signal_) {
signal_ = nullptr;
}
}
}
namespace {
* @tc.number : VIDEO_ENCODE_ILLEGAL_PARA_0100
* @tc.name : CreateByMime para1 error
* @tc.desc : param test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_ILLEGAL_PARA_0100, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByMime("");
ASSERT_EQ(nullptr, venc_);
}
* @tc.number : VIDEO_ENCODE_ILLEGAL_PARA_0200
* @tc.name : CreateByMime para2 error
* @tc.desc : param test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_ILLEGAL_PARA_0200, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByMime("");
ASSERT_EQ(nullptr, venc_);
}
* @tc.number : VIDEO_ENCODE_ILLEGAL_PARA_0300
* @tc.name : CreateByName para1 error
* @tc.desc : param test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_ILLEGAL_PARA_0300, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName("");
ASSERT_EQ(nullptr, venc_);
}
* @tc.number : VIDEO_ENCODE_ILLEGAL_PARA_0400
* @tc.name : CreateByName para2 error
* @tc.desc : param test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_ILLEGAL_PARA_0400, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName("");
ASSERT_EQ(nullptr, venc_);
}
* @tc.number : VIDEO_ENCODE_ILLEGAL_PARA_0500
* @tc.name : SetCallback para error
* @tc.desc : param test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_ILLEGAL_PARA_0500, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByMime(g_codecMime);
ASSERT_NE(nullptr, venc_);
std::shared_ptr<VEncInnerCallback> cb_ = make_shared<VEncInnerCallback>(nullptr);
int32_t ret = venc_->SetCallback(cb_);
ASSERT_EQ(AVCS_ERR_OK, ret);
}
* @tc.number : VIDEO_ENCODE_ILLEGAL_PARA_0600
* @tc.name : Configure para not enough
* @tc.desc : param test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_ILLEGAL_PARA_0600, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByMime(g_codecMime);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_BITRATE, 100000);
int32_t ret = venc_->Configure(format);
ASSERT_EQ(ret, AVCS_ERR_INVALID_VAL);
}
* @tc.number : VIDEO_ENCODE_ILLEGAL_PARA_0700
* @tc.name : ReleaseOutputBuffer para error
* @tc.desc : param test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_ILLEGAL_PARA_0700, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByMime(g_codecMime);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, 1080);
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, 1080);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::YUVI420));
ASSERT_EQ(AVCS_ERR_OK, venc_->Configure(format));
ASSERT_EQ(AVCS_ERR_OK, venc_->Start());
usleep(1000000);
ASSERT_EQ(AVCS_ERR_INVALID_STATE, venc_->ReleaseOutputBuffer(9999999));
}
* @tc.number : VIDEO_ENCODE_ILLEGAL_PARA_0800
* @tc.name : QueueInputBuffer para error
* @tc.desc : param test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_ILLEGAL_PARA_0800, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByMime(g_codecMime);
ASSERT_NE(nullptr, venc_);
AVCodecBufferInfo info;
info.presentationTimeUs = -1;
info.size = -1;
info.offset = 0;
AVCodecBufferFlag flag = AVCODEC_BUFFER_FLAG_EOS;
ASSERT_EQ(AVCS_ERR_INVALID_STATE, venc_->QueueInputBuffer(0, info, flag));
}
* @tc.number : VIDEO_ENCODE_API_0100
* @tc.name : CreateByName CreateByName
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0100, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
std::shared_ptr<AVCodecVideoEncoder> venc2_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
ASSERT_EQ(AVCS_ERR_OK, venc2_->Release());
venc2_ = nullptr;
}
* @tc.number : VIDEO_ENCODE_API_0200
* @tc.name : CreateByName configure configure
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0200, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, DEFAULT_WIDTH);
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, DEFAULT_HEIGHT);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::NV12));
ASSERT_EQ(AVCS_ERR_OK, venc_->Configure(format));
ASSERT_EQ(AVCS_ERR_INVALID_STATE, venc_->Configure(format));
}
* @tc.number : VIDEO_ENCODE_API_0300
* @tc.name : CreateByName configure start start
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0300, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, DEFAULT_WIDTH);
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, DEFAULT_HEIGHT);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::NV12));
ASSERT_EQ(AVCS_ERR_OK, venc_->Configure(format));
ASSERT_EQ(AVCS_ERR_OK, venc_->Start());
ASSERT_EQ(AVCS_ERR_INVALID_STATE, venc_->Start());
}
* @tc.number : VIDEO_ENCODE_API_0400
* @tc.name : CreateByName configure start stop stop
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0400, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, DEFAULT_WIDTH);
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, DEFAULT_HEIGHT);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::NV12));
ASSERT_EQ(AVCS_ERR_OK, venc_->Configure(format));
ASSERT_EQ(AVCS_ERR_OK, venc_->Start());
ASSERT_EQ(AVCS_ERR_OK, venc_->Stop());
ASSERT_EQ(AVCS_ERR_OK, venc_->Stop());
}
* @tc.number : VIDEO_ENCODE_API_0500
* @tc.name : CreateByName configure start stop reset reset
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0500, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, DEFAULT_WIDTH);
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, DEFAULT_HEIGHT);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::NV12));
ASSERT_EQ(AVCS_ERR_OK, venc_->Configure(format));
ASSERT_EQ(AVCS_ERR_OK, venc_->Start());
ASSERT_EQ(AVCS_ERR_OK, venc_->Stop());
ASSERT_EQ(AVCS_ERR_OK, venc_->Reset());
ASSERT_EQ(AVCS_ERR_OK, venc_->Reset());
}
* @tc.number : VIDEO_ENCODE_API_0600
* @tc.name : CreateByName configure start EOS EOS
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0600, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, DEFAULT_WIDTH);
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, DEFAULT_HEIGHT);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::NV12));
ASSERT_EQ(AVCS_ERR_OK, venc_->Configure(format));
std::shared_ptr<VEncInnerCallback> cb_ = make_shared<VEncInnerCallback>(signal_);
ASSERT_EQ(AVCS_ERR_OK, venc_->SetCallback(cb_));
ASSERT_EQ(AVCS_ERR_OK, venc_->Start());
unique_lock<mutex> lock(signal_->inMutex_);
signal_->inCond_.wait(lock, [] { return signal_->inIdxQueue_.size() > 1; });
uint32_t index = signal_->inIdxQueue_.front();
AVCodecBufferInfo info;
info.presentationTimeUs = 0;
info.size = 0;
info.offset = 0;
AVCodecBufferFlag flag = AVCODEC_BUFFER_FLAG_EOS;
ASSERT_EQ(AVCS_ERR_OK, venc_->QueueInputBuffer(index, info, flag));
signal_->inIdxQueue_.pop();
index = signal_->inIdxQueue_.front();
ASSERT_EQ(AVCS_ERR_INVALID_STATE, venc_->QueueInputBuffer(index, info, flag));
signal_->inIdxQueue_.pop();
}
* @tc.number : VIDEO_ENCODE_API_0700
* @tc.name : CreateByName configure start flush flush
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0700, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, DEFAULT_WIDTH);
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, DEFAULT_HEIGHT);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::NV12));
ASSERT_EQ(AVCS_ERR_OK, venc_->Configure(format));
ASSERT_EQ(AVCS_ERR_OK, venc_->Start());
ASSERT_EQ(AVCS_ERR_OK, venc_->Flush());
ASSERT_EQ(AVCS_ERR_OK, venc_->Flush());
}
* @tc.number : VIDEO_ENCODE_API_0800
* @tc.name : CreateByName configure start stop release
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0800, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, DEFAULT_WIDTH);
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, DEFAULT_HEIGHT);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::NV12));
ASSERT_EQ(AVCS_ERR_OK, venc_->Configure(format));
ASSERT_EQ(AVCS_ERR_OK, venc_->Start());
ASSERT_EQ(AVCS_ERR_OK, venc_->Stop());
ASSERT_EQ(AVCS_ERR_OK, venc_->Release());
venc_ = nullptr;
}
* @tc.number : VIDEO_ENCODE_API_0900
* @tc.name : CreateByMime CreateByMime
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_0900, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByMime(g_codecMime);
ASSERT_NE(nullptr, venc_);
std::shared_ptr<AVCodecVideoEncoder> venc2_ = VideoEncoderFactory::CreateByMime(g_codecMime);
ASSERT_NE(nullptr, venc_);
ASSERT_EQ(AVCS_ERR_OK, venc2_->Release());
venc2_ = nullptr;
}
* @tc.number : VIDEO_ENCODE_API_1000
* @tc.name : repeat SetCallback
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_1000, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
std::shared_ptr<VEncInnerCallback> cb_ = make_shared<VEncInnerCallback>(nullptr);
ASSERT_EQ(AVCS_ERR_OK, venc_->SetCallback(cb_));
ASSERT_EQ(AVCS_ERR_OK, venc_->SetCallback(cb_));
}
* @tc.number : VIDEO_ENCODE_API_1100
* @tc.name : repeat GetOutputFormat
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_1100, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
ASSERT_EQ(AVCS_ERR_OK, venc_->GetOutputFormat(format));
ASSERT_EQ(AVCS_ERR_OK, venc_->GetOutputFormat(format));
}
* @tc.number : VIDEO_ENCODE_API_1200
* @tc.name : repeat SetParameter
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_1200, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
format.PutIntValue(MediaDescriptionKey::MD_KEY_WIDTH, DEFAULT_WIDTH);
format.PutIntValue(MediaDescriptionKey::MD_KEY_HEIGHT, DEFAULT_HEIGHT);
format.PutIntValue(MediaDescriptionKey::MD_KEY_PIXEL_FORMAT, static_cast<int32_t>(VideoPixelFormat::NV12));
ASSERT_EQ(AVCS_ERR_INVALID_STATE, venc_->SetParameter(format));
ASSERT_EQ(AVCS_ERR_INVALID_STATE, venc_->SetParameter(format));
}
* @tc.number : VIDEO_ENCODE_API_1300
* @tc.name : repeat GetInputFormat
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_API_1300, TestSize.Level2)
{
venc_ = VideoEncoderFactory::CreateByName(g_codecName);
ASSERT_NE(nullptr, venc_);
Format format;
int32_t ret = venc_->GetInputFormat(format);
ASSERT_EQ(AVCS_ERR_OK, ret);
ret = venc_->GetInputFormat(format);
ASSERT_EQ(AVCS_ERR_OK, ret);
}
* @tc.number : VIDEO_ENCODE_INNER_REPEAT_0100
* @tc.name : set frame after 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_REPEAT_0100, TestSize.Level0)
{
if (cap != nullptr) {
auto vEncInnerSample = make_unique<VEncNdkInnerSample>();
vEncInnerSample->INP_DIR = "/data/test/media/1280_720_nv.yuv";
vEncInnerSample->DEFAULT_WIDTH = 1280;
vEncInnerSample->DEFAULT_HEIGHT = 720;
vEncInnerSample->DEFAULT_BITRATE_MODE = CBR;
vEncInnerSample->surfaceInput = true;
vEncInnerSample->enableRepeat = true;
vEncInnerSample->setMaxCount = true;
vEncInnerSample->DEFAULT_FRAME_AFTER = 0;
vEncInnerSample->DEFAULT_MAX_COUNT = -1;
ASSERT_EQ(AVCS_ERR_OK, vEncInnerSample->CreateByName(g_codecName));
ASSERT_EQ(AVCS_ERR_OK, vEncInnerSample->SetCallback());
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncInnerSample->Configure());
}
}
* @tc.number : VIDEO_ENCODE_INNER_REPEAT_0200
* @tc.name : set frame after -1
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_REPEAT_0200, TestSize.Level1)
{
if (cap != nullptr) {
auto vEncInnerSample = make_unique<VEncNdkInnerSample>();
vEncInnerSample->INP_DIR = "/data/test/media/1280_720_nv.yuv";
vEncInnerSample->DEFAULT_WIDTH = 1280;
vEncInnerSample->DEFAULT_HEIGHT = 720;
vEncInnerSample->DEFAULT_BITRATE_MODE = CBR;
vEncInnerSample->surfaceInput = true;
vEncInnerSample->enableRepeat = true;
vEncInnerSample->setMaxCount = true;
vEncInnerSample->DEFAULT_FRAME_AFTER = -1;
vEncInnerSample->DEFAULT_MAX_COUNT = -1;
ASSERT_EQ(AVCS_ERR_OK, vEncInnerSample->CreateByName(g_codecName));
ASSERT_EQ(AVCS_ERR_OK, vEncInnerSample->SetCallback());
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncInnerSample->Configure());
}
}
* @tc.number : VIDEO_ENCODE_INNER_REPEAT_0300
* @tc.name : set max count 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_REPEAT_0300, TestSize.Level1)
{
if (cap != nullptr) {
auto vEncInnerSample = make_unique<VEncNdkInnerSample>();
vEncInnerSample->INP_DIR = "/data/test/media/1280_720_nv.yuv";
vEncInnerSample->DEFAULT_WIDTH = 1280;
vEncInnerSample->DEFAULT_HEIGHT = 720;
vEncInnerSample->DEFAULT_BITRATE_MODE = CBR;
vEncInnerSample->surfaceInput = true;
vEncInnerSample->enableRepeat = true;
vEncInnerSample->setMaxCount = true;
vEncInnerSample->DEFAULT_FRAME_AFTER = 1;
vEncInnerSample->DEFAULT_MAX_COUNT = 0;
ASSERT_EQ(AVCS_ERR_OK, vEncInnerSample->CreateByName(g_codecName));
ASSERT_EQ(AVCS_ERR_OK, vEncInnerSample->SetCallback());
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncInnerSample->Configure());
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0010
* @tc.name : set width of bufferConfig less than 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0010, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = -1,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0020
* @tc.name : set width of bufferConfig be equal to 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0020, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 0,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0030
* @tc.name : set width of bufferConfig be greater than video width
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0030, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = vEncSample->DEFAULT_WIDTH,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = vEncSample->DEFAULT_WIDTH + 1;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0040
* @tc.name : set height of bufferConfig less than 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0040, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = -1,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0050
* @tc.name : set height of bufferConfig be equal to 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0050, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 0,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0060
* @tc.name : set height of bufferConfig be greater than video height
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0060, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = vEncSample->DEFAULT_HEIGHT,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = vEncSample->DEFAULT_HEIGHT + 1;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0070
* @tc.name : set format of bufferConfig is GRAPHIC_PIXEL_FMT_YCBCR_420_P
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0070, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_YCBCR_420_P,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0080
* @tc.name : set format of bufferConfig is GRAPHIC_PIXEL_FMT_YCBCR_420_SP
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0080, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_YCBCR_420_SP,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0090
* @tc.name : set format of bufferConfig is GRAPHIC_PIXEL_FMT_YCRCB_420_SP
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0090, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_YCRCB_420_SP,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0100
* @tc.name : set format of bufferConfig is GRAPHIC_PIXEL_FMT_BUTT
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0100, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_BUTT,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0110
* @tc.name : set VIDEO_COORDINATE_X of format less than 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0110, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = -1;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0120
* @tc.name : set VIDEO_COORDINATE_X of format greater than video width
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0120, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = vEncSample->DEFAULT_WIDTH + 1;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0130
* @tc.name : set VIDEO_COORDINATE_X of format add waterMark width greater than video width
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0130, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = vEncSample->DEFAULT_HEIGHT - 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0140
* @tc.name : set VIDEO_COORDINATE_Y of format less than 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0140, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = -1;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0150
* @tc.name : set VIDEO_COORDINATE_Y of format greater than video height
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0150, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = vEncSample->DEFAULT_HEIGHT + 1;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0160
* @tc.name : set VIDEO_COORDINATE_Y of format add waterMark height greater than video height
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0160, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = vEncSample->DEFAULT_HEIGHT - 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0170
* @tc.name : set VIDEO_COORDINATE_W of format less than 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0170, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = -1;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0180
* @tc.name : set VIDEO_COORDINATE_W of format greater than video width
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0180, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = -1;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0190
* @tc.name : set VIDEO_COORDINATE_W of format be equal to 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0190, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = 0;
vEncSample->videoCoordinateHeight = bufferConfig.height;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0200
* @tc.name : set VIDEO_COORDINATE_H of format less than 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0200, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = -1;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0210
* @tc.name : set VIDEO_COORDINATE_H of format greater than video height
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0210, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = bufferConfig.height - 1;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
* @tc.number : VIDEO_ENCODE_INNER_WATERMARK_API_0220
* @tc.name : set VIDEO_COORDINATE_H of format be equal to 0
* @tc.desc : api test
*/
HWTEST_F(HwEncInnerApiNdkTest, VIDEO_ENCODE_INNER_WATERMARK_API_0220, TestSize.Level1)
{
auto vEncSample = make_unique<VEncNdkInnerSample>();
BufferRequestConfig bufferConfig = {
.width = 400,
.height = 400,
.strideAlignment = 0x8,
.format = GraphicPixelFormat::GRAPHIC_PIXEL_FMT_RGBA_8888,
.usage = BUFFER_USAGE_CPU_READ | BUFFER_USAGE_CPU_WRITE | BUFFER_USAGE_MEM_DMA,
.timeout = 0,
};
vEncSample->surfaceInput = true;
vEncSample->enableWaterMark = true;
vEncSample->videoCoordinateX = 100;
vEncSample->videoCoordinateY = 100;
vEncSample->videoCoordinateWidth = bufferConfig.width;
vEncSample->videoCoordinateHeight = 0;
ASSERT_EQ(AV_ERR_OK, vEncSample->CreateByName(g_codecName));
ASSERT_EQ(AV_ERR_OK, vEncSample->SetCallback());
ASSERT_EQ(AV_ERR_OK, vEncSample->Configure());
if (!vEncSample->GetWaterMarkCapability(g_codecMime)) {
ASSERT_EQ(AVCS_ERR_UNSUPPORT, vEncSample->SetCustomBuffer(bufferConfig));
} else {
ASSERT_EQ(AVCS_ERR_INVALID_VAL, vEncSample->SetCustomBuffer(bufferConfig));
}
}
}