openh264/test/api/decode_encode_test.cpp

140 lines
4.0 KiB
C++
Raw Normal View History

#include <gtest/gtest.h>
#include "codec_def.h"
#include "utils/HashFunctions.h"
#include "utils/BufferedData.h"
#include "utils/InputStream.h"
#include "BaseDecoderTest.h"
#include "BaseEncoderTest.h"
#include <string>
2014-06-26 03:50:41 +02:00
static void UpdateHashFromFrame (const SFrameBSInfo& info, SHA1Context* ctx) {
for (int i = 0; i < info.iLayerNum; ++i) {
const SLayerBSInfo& layerInfo = info.sLayerInfo[i];
int layerSize = 0;
for (int j = 0; j < layerInfo.iNalCount; ++j) {
layerSize += layerInfo.pNalLengthInByte[j];
}
2014-06-26 03:50:41 +02:00
SHA1Input (ctx, layerInfo.pBsBuf, layerSize);
}
}
2014-06-26 03:50:41 +02:00
static void WritePlaneBuffer (BufferedData* buf, const uint8_t* plane,
int width, int height, int stride) {
for (int i = 0; i < height; i++) {
2014-06-26 03:50:41 +02:00
if (!buf->PushBack (plane, width)) {
FAIL() << "unable to allocate memory";
}
plane += stride;
}
}
struct DecodeEncodeFileParam {
const char* fileName;
const char* hashStr;
int width;
int height;
float frameRate;
};
class DecodeEncodeTest : public ::testing::TestWithParam<DecodeEncodeFileParam>,
2014-06-26 03:50:41 +02:00
public BaseDecoderTest, public BaseDecoderTest::Callback,
public BaseEncoderTest , public BaseEncoderTest::Callback,
public InputStream {
public:
virtual void SetUp() {
BaseDecoderTest::SetUp();
if (HasFatalFailure()) {
return;
}
BaseEncoderTest::SetUp();
if (HasFatalFailure()) {
return;
}
2014-06-26 03:50:41 +02:00
SHA1Reset (&ctx_);
}
virtual void TearDown() {
BaseDecoderTest::TearDown();
BaseEncoderTest::TearDown();
}
2014-06-26 03:50:41 +02:00
virtual void onDecodeFrame (const Frame& frame) {
const Plane& y = frame.y;
const Plane& u = frame.u;
const Plane& v = frame.v;
2014-06-26 03:50:41 +02:00
WritePlaneBuffer (&buf_, y.data, y.width, y.height, y.stride);
WritePlaneBuffer (&buf_, u.data, u.width, u.height, u.stride);
WritePlaneBuffer (&buf_, v.data, v.width, v.height, v.stride);
}
2014-06-26 03:50:41 +02:00
virtual void onEncodeFrame (const SFrameBSInfo& frameInfo) {
UpdateHashFromFrame (frameInfo, &ctx_);
}
2014-06-26 03:50:41 +02:00
virtual int read (void* ptr, size_t len) {
while (buf_.Length() < len) {
2014-06-26 03:50:41 +02:00
bool hasNext = DecodeNextFrame (this);
if (HasFatalFailure()) {
return -1;
}
if (!hasNext) {
if (buf_.Length() == 0) {
return -1;
}
break;
}
}
2014-06-26 03:50:41 +02:00
return buf_.PopFront (static_cast<uint8_t*> (ptr), len);
}
protected:
SHA1Context ctx_;
BufferedData buf_;
};
2014-10-29 06:50:18 +01:00
void DecEncFileParamToParamExt (DecodeEncodeFileParam * pDecEncFileParam, SEncParamExt* pEnxParamExt) {
ASSERT_TRUE (NULL != pDecEncFileParam && NULL != pEnxParamExt);
pEnxParamExt->iPicWidth = pDecEncFileParam->width;
pEnxParamExt->iPicHeight = pDecEncFileParam->height;
pEnxParamExt->fMaxFrameRate = pDecEncFileParam->frameRate;
//default value
pEnxParamExt->iUsageType = CAMERA_VIDEO_REAL_TIME;
pEnxParamExt->iSpatialLayerNum = 1;
pEnxParamExt->bEnableDenoise = false;
pEnxParamExt->bIsLosslessLink = false;
pEnxParamExt->bEnableLongTermReference = false;
pEnxParamExt->iEntropyCodingModeFlag = 0;
for (int i = 0; i < pEnxParamExt->iSpatialLayerNum; i++) {
pEnxParamExt->sSpatialLayers[i].sSliceCfg.uiSliceMode = SM_SINGLE_SLICE;
}
}
2014-06-26 03:50:41 +02:00
TEST_P (DecodeEncodeTest, CompareOutput) {
DecodeEncodeFileParam p = GetParam();
2014-10-29 06:50:18 +01:00
SEncParamExt EnxParamExt;
DecEncFileParamToParamExt(&p,&EnxParamExt);
#if defined(ANDROID_NDK)
std::string filename = std::string ("/sdcard/") + p.fileName;
ASSERT_TRUE (Open (filename.c_str()));
#else
2014-06-26 03:50:41 +02:00
ASSERT_TRUE (Open (p.fileName));
#endif
2014-10-29 06:50:18 +01:00
EncodeStream (this, &EnxParamExt, this);
unsigned char digest[SHA_DIGEST_LENGTH];
2014-06-26 03:50:41 +02:00
SHA1Result (&ctx_, digest);
if (!HasFatalFailure()) {
2014-06-26 03:50:41 +02:00
CompareHash (digest, p.hashStr);
}
}
static const DecodeEncodeFileParam kFileParamArray[] = {
2014-06-24 08:49:28 +02:00
{"res/test_vd_1d.264", "a4c7299ec1a7bacd5819685e221a79ac2b56cdbc", 320, 192, 12.0f},
{"res/test_vd_rc.264", "106fd8cc978c1801b0d1f8297e9b7f17d5336e15", 320, 192, 12.0f},
};
2014-06-26 03:50:41 +02:00
INSTANTIATE_TEST_CASE_P (DecodeEncodeFile, DecodeEncodeTest,
::testing::ValuesIn (kFileParamArray));