#include #include #include #include "cpu.h" #include "cpu_core.h" #include "typedef.h" #include "IWelsVP.h" #include "ScrollDetection.h" #include "ScrollDetectionFuncs.h" #include "utils/DataGenerator.h" using namespace nsWelsVP; #define ASSERT_MEMORY_FAIL2X(A, B) \ if (NULL == B) { \ delete []A;\ ASSERT_TRUE(0); \ } TEST(ScrollDetectionTest,TestScroll) { uint8_t* pSrc, *pRef; int32_t iWidthSets[4] = {640,1024,1280,1980}; int32_t iHeightSets[4] = {360,768,720,1080}; int32_t iStride = 0; int32_t iIdx = 0; for(int32_t i=0; i<4; i++){ int32_t iWidth = iWidthSets[i]; int32_t iHeight = iHeightSets[i]; iStride = iWidth + 16; pSrc = new uint8_t[iHeight*iStride]; ASSERT_TRUE(NULL != pSrc); pRef = new uint8_t[iHeight*iStride]; ASSERT_MEMORY_FAIL2X(pSrc, pRef) RandomPixelDataGenerator(pRef, iWidth, iHeight, iStride, iIdx ); int32_t iMvRange = iHeight/3; int32_t iScrollMv = rand()%(iMvRange<<1) - iMvRange; uint8_t* pSrcTmp = pSrc; uint8_t* pRefTmp = pRef; for (int32_t j=0;j=0 && (j+iScrollMv)Set(iMethodIdx, (&sScrollDetectionResult)); int32_t ret = pTest->Process(iMethodIdx,&sSrcMap, &sRefMap); EXPECT_EQ(ret,0); pTest->Get(iMethodIdx, (&sScrollDetectionResult)); EXPECT_EQ(sScrollDetectionResult.bScrollDetectFlag,1); EXPECT_EQ(sScrollDetectionResult.iScrollMvY,iScrollMv); delete pTest; delete []pSrc; delete []pRef; } }