2014-01-14 15:48:20 +08:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include "codec_def.h"
|
|
|
|
#include "utils/HashFunctions.h"
|
2014-01-18 19:31:54 +08:00
|
|
|
#include "utils/BufferedData.h"
|
|
|
|
#include "utils/InputStream.h"
|
2014-01-14 15:48:20 +08:00
|
|
|
#include "BaseDecoderTest.h"
|
|
|
|
#include "BaseEncoderTest.h"
|
2014-07-28 13:25:27 +08:00
|
|
|
#include <string>
|
2014-06-25 18:50:41 -07:00
|
|
|
static void UpdateHashFromFrame (const SFrameBSInfo& info, SHA1Context* ctx) {
|
2014-01-14 15:48:20 +08:00
|
|
|
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) {
|
2014-05-14 16:00:36 +08:00
|
|
|
layerSize += layerInfo.pNalLengthInByte[j];
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
2014-06-25 18:50:41 -07:00
|
|
|
SHA1Input (ctx, layerInfo.pBsBuf, layerSize);
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
static void WritePlaneBuffer (BufferedData* buf, const uint8_t* plane,
|
|
|
|
int width, int height, int stride) {
|
2014-01-14 15:48:20 +08:00
|
|
|
for (int i = 0; i < height; i++) {
|
2014-06-25 18:50:41 -07:00
|
|
|
if (!buf->PushBack (plane, width)) {
|
2014-01-18 19:31:54 +08:00
|
|
|
FAIL() << "unable to allocate memory";
|
|
|
|
}
|
2014-01-14 15:48:20 +08:00
|
|
|
plane += stride;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct DecodeEncodeFileParam {
|
|
|
|
const char* fileName;
|
|
|
|
const char* hashStr;
|
|
|
|
int width;
|
|
|
|
int height;
|
|
|
|
float frameRate;
|
|
|
|
};
|
|
|
|
|
|
|
|
class DecodeEncodeTest : public ::testing::TestWithParam<DecodeEncodeFileParam>,
|
2014-06-25 18:50:41 -07:00
|
|
|
public BaseDecoderTest, public BaseDecoderTest::Callback,
|
|
|
|
public BaseEncoderTest , public BaseEncoderTest::Callback,
|
|
|
|
public InputStream {
|
2014-01-14 15:48:20 +08:00
|
|
|
public:
|
|
|
|
virtual void SetUp() {
|
|
|
|
BaseDecoderTest::SetUp();
|
|
|
|
if (HasFatalFailure()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
BaseEncoderTest::SetUp();
|
|
|
|
if (HasFatalFailure()) {
|
|
|
|
return;
|
|
|
|
}
|
2014-06-25 18:50:41 -07:00
|
|
|
SHA1Reset (&ctx_);
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual void TearDown() {
|
|
|
|
BaseDecoderTest::TearDown();
|
|
|
|
BaseEncoderTest::TearDown();
|
|
|
|
}
|
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
virtual void onDecodeFrame (const Frame& frame) {
|
2014-01-14 15:48:20 +08:00
|
|
|
const Plane& y = frame.y;
|
|
|
|
const Plane& u = frame.u;
|
|
|
|
const Plane& v = frame.v;
|
2014-06-25 18:50:41 -07: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-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
virtual void onEncodeFrame (const SFrameBSInfo& frameInfo) {
|
|
|
|
UpdateHashFromFrame (frameInfo, &ctx_);
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
virtual int read (void* ptr, size_t len) {
|
2014-01-18 19:31:54 +08:00
|
|
|
while (buf_.Length() < len) {
|
2014-06-25 18:50:41 -07:00
|
|
|
bool hasNext = DecodeNextFrame (this);
|
2014-01-18 19:31:54 +08:00
|
|
|
if (HasFatalFailure()) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
if (!hasNext) {
|
|
|
|
if (buf_.Length() == 0) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2015-01-16 10:39:55 +02:00
|
|
|
return (int) buf_.PopFront (static_cast<uint8_t*> (ptr), len);
|
2014-01-18 19:31:54 +08:00
|
|
|
}
|
|
|
|
|
2014-01-14 15:48:20 +08:00
|
|
|
protected:
|
2014-01-17 10:43:26 +02:00
|
|
|
SHA1Context ctx_;
|
2014-01-18 19:31:54 +08:00
|
|
|
BufferedData buf_;
|
2014-01-14 15:48:20 +08:00
|
|
|
};
|
|
|
|
|
2015-03-18 13:44:03 +08:00
|
|
|
void DecEncFileParamToParamExt (DecodeEncodeFileParam* pDecEncFileParam, SEncParamExt* pEnxParamExt) {
|
2014-10-29 13:50:18 +08:00
|
|
|
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++) {
|
2015-11-10 09:50:06 -08:00
|
|
|
pEnxParamExt->sSpatialLayers[i].sSliceArgument.uiSliceMode = SM_SINGLE_SLICE;
|
2014-10-29 13:50:18 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2014-06-25 18:50:41 -07:00
|
|
|
TEST_P (DecodeEncodeTest, CompareOutput) {
|
2014-01-14 15:48:20 +08:00
|
|
|
DecodeEncodeFileParam p = GetParam();
|
2014-10-29 13:50:18 +08:00
|
|
|
SEncParamExt EnxParamExt;
|
2015-03-18 13:44:03 +08:00
|
|
|
DecEncFileParamToParamExt (&p, &EnxParamExt);
|
2014-10-29 13:50:18 +08:00
|
|
|
|
2014-07-28 13:25:27 +08:00
|
|
|
#if defined(ANDROID_NDK)
|
|
|
|
std::string filename = std::string ("/sdcard/") + p.fileName;
|
|
|
|
ASSERT_TRUE (Open (filename.c_str()));
|
|
|
|
#else
|
2014-06-25 18:50:41 -07:00
|
|
|
ASSERT_TRUE (Open (p.fileName));
|
2014-07-28 13:25:27 +08:00
|
|
|
#endif
|
2014-10-29 13:50:18 +08:00
|
|
|
EncodeStream (this, &EnxParamExt, this);
|
2014-01-14 15:48:20 +08:00
|
|
|
unsigned char digest[SHA_DIGEST_LENGTH];
|
2014-06-25 18:50:41 -07:00
|
|
|
SHA1Result (&ctx_, digest);
|
2014-01-14 15:48:20 +08:00
|
|
|
if (!HasFatalFailure()) {
|
2014-06-25 18:50:41 -07:00
|
|
|
CompareHash (digest, p.hashStr);
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
static const DecodeEncodeFileParam kFileParamArray[] = {
|
2015-11-13 17:16:26 +08:00
|
|
|
{"res/test_vd_1d.264", "cb3ec7a1bf37d0c08118f00009befb6f11dace3c", 320, 192, 12.0f},
|
|
|
|
{"res/test_vd_rc.264", "f231547ee7a3e6e4f1a05425280c41f285df390c", 320, 192, 12.0f},
|
2014-01-14 15:48:20 +08:00
|
|
|
};
|
|
|
|
|
2014-07-25 14:05:36 +08:00
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
INSTANTIATE_TEST_CASE_P (DecodeEncodeFile, DecodeEncodeTest,
|
|
|
|
::testing::ValuesIn (kFileParamArray));
|