2013-09-12 23:41:49 -05:00
|
|
|
/**
|
|
|
|
|
* @file
|
|
|
|
|
* @brief Unit tests for openshot::FFmpegReader
|
|
|
|
|
* @author Jonathan Thomas <jonathan@openshot.org>
|
|
|
|
|
*
|
|
|
|
|
* @section LICENSE
|
|
|
|
|
*
|
2014-03-29 18:49:22 -05:00
|
|
|
* Copyright (c) 2008-2014 OpenShot Studios, LLC
|
|
|
|
|
* <http://www.openshotstudios.com/>. This file is part of
|
|
|
|
|
* OpenShot Library (libopenshot), an open-source project dedicated to
|
|
|
|
|
* delivering high quality video editing and animation solutions to the
|
|
|
|
|
* world. For more information visit <http://www.openshot.org/>.
|
2013-09-12 23:41:49 -05:00
|
|
|
*
|
2014-03-29 18:49:22 -05:00
|
|
|
* OpenShot Library (libopenshot) is free software: you can redistribute it
|
2014-07-11 16:52:14 -05:00
|
|
|
* and/or modify it under the terms of the GNU Lesser General Public License
|
2014-03-29 18:49:22 -05:00
|
|
|
* as published by the Free Software Foundation, either version 3 of the
|
|
|
|
|
* License, or (at your option) any later version.
|
2013-09-12 23:41:49 -05:00
|
|
|
*
|
2014-03-29 18:49:22 -05:00
|
|
|
* OpenShot Library (libopenshot) is distributed in the hope that it will be
|
|
|
|
|
* useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2014-07-11 16:52:14 -05:00
|
|
|
* GNU Lesser General Public License for more details.
|
2013-09-12 23:41:49 -05:00
|
|
|
*
|
2014-07-11 16:52:14 -05:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
2014-03-29 18:49:22 -05:00
|
|
|
* along with OpenShot Library. If not, see <http://www.gnu.org/licenses/>.
|
2013-09-12 23:41:49 -05:00
|
|
|
*/
|
|
|
|
|
|
2012-07-09 01:22:11 -05:00
|
|
|
#include "UnitTest++.h"
|
|
|
|
|
#include "../include/OpenShot.h"
|
2015-09-28 22:17:29 -05:00
|
|
|
#include "../include/Tests.h"
|
2012-07-09 01:22:11 -05:00
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
using namespace openshot;
|
|
|
|
|
|
|
|
|
|
TEST(FFmpegReader_Invalid_Path)
|
|
|
|
|
{
|
|
|
|
|
// Check invalid path
|
2012-10-10 01:07:47 -05:00
|
|
|
CHECK_THROW(FFmpegReader(""), InvalidFile);
|
2012-10-09 01:45:34 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(FFmpegReader_GetFrame_Before_Opening)
|
|
|
|
|
{
|
|
|
|
|
// Create a reader
|
2015-09-28 22:05:50 -05:00
|
|
|
stringstream path;
|
|
|
|
|
path << TEST_MEDIA_PATH << "piano.wav";
|
|
|
|
|
FFmpegReader r(path.str());
|
2012-10-09 01:45:34 -05:00
|
|
|
|
|
|
|
|
// Check invalid path
|
|
|
|
|
CHECK_THROW(r.GetFrame(1), ReaderClosed);
|
2012-07-09 01:22:11 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(FFmpegReader_Check_Audio_File)
|
|
|
|
|
{
|
|
|
|
|
// Create a reader
|
2015-09-28 22:05:50 -05:00
|
|
|
stringstream path;
|
|
|
|
|
path << TEST_MEDIA_PATH << "piano.wav";
|
|
|
|
|
FFmpegReader r(path.str());
|
2012-10-09 01:45:34 -05:00
|
|
|
r.Open();
|
2012-07-09 01:22:11 -05:00
|
|
|
|
|
|
|
|
// Get frame 1
|
2017-08-20 17:37:39 -05:00
|
|
|
std::shared_ptr<Frame> f = r.GetFrame(1);
|
2012-07-09 01:22:11 -05:00
|
|
|
|
|
|
|
|
// Get the number of channels and samples
|
2012-08-15 17:27:14 -05:00
|
|
|
float *samples = f->GetAudioSamples(0);
|
2012-07-09 01:22:11 -05:00
|
|
|
|
|
|
|
|
// Check audio properties
|
2012-08-15 17:27:14 -05:00
|
|
|
CHECK_EQUAL(2, f->GetAudioChannelsCount());
|
2015-03-08 22:24:12 -05:00
|
|
|
CHECK_EQUAL(332, f->GetAudioSamplesCount());
|
2012-07-09 01:22:11 -05:00
|
|
|
|
|
|
|
|
// Check actual sample values (to be sure the waveform is correct)
|
|
|
|
|
CHECK_CLOSE(0.0f, samples[0], 0.00001);
|
|
|
|
|
CHECK_CLOSE(0.0f, samples[50], 0.00001);
|
|
|
|
|
CHECK_CLOSE(0.0f, samples[100], 0.00001);
|
|
|
|
|
CHECK_CLOSE(0.0f, samples[200], 0.00001);
|
2018-06-17 10:29:17 -07:00
|
|
|
CHECK_CLOSE(0.160781f, samples[230], 0.00001);
|
|
|
|
|
CHECK_CLOSE(-0.06125f, samples[300], 0.00001);
|
2012-07-09 01:44:36 -05:00
|
|
|
|
|
|
|
|
// Close reader
|
|
|
|
|
r.Close();
|
2012-07-09 01:22:11 -05:00
|
|
|
}
|
|
|
|
|
|
2012-07-09 01:44:36 -05:00
|
|
|
TEST(FFmpegReader_Check_Video_File)
|
|
|
|
|
{
|
|
|
|
|
// Create a reader
|
2015-09-28 22:05:50 -05:00
|
|
|
stringstream path;
|
|
|
|
|
path << TEST_MEDIA_PATH << "test.mp4";
|
|
|
|
|
FFmpegReader r(path.str());
|
2012-10-09 01:45:34 -05:00
|
|
|
r.Open();
|
2012-07-09 01:44:36 -05:00
|
|
|
|
|
|
|
|
// Get frame 1
|
2017-08-20 17:37:39 -05:00
|
|
|
std::shared_ptr<Frame> f = r.GetFrame(1);
|
2012-07-09 01:44:36 -05:00
|
|
|
|
|
|
|
|
// Get the image data
|
2015-06-01 00:20:14 -07:00
|
|
|
const unsigned char* pixels = f->GetPixels(10);
|
|
|
|
|
int pixel_index = 112 * 4; // pixel 112 (4 bytes per pixel)
|
2012-07-09 01:44:36 -05:00
|
|
|
|
|
|
|
|
// Check image properties on scanline 10, pixel 112
|
2015-06-01 00:20:14 -07:00
|
|
|
CHECK_EQUAL(21, (int)pixels[pixel_index]);
|
|
|
|
|
CHECK_EQUAL(191, (int)pixels[pixel_index + 1]);
|
|
|
|
|
CHECK_EQUAL(0, (int)pixels[pixel_index + 2]);
|
|
|
|
|
CHECK_EQUAL(255, (int)pixels[pixel_index + 3]);
|
2012-07-09 01:44:36 -05:00
|
|
|
|
2019-05-31 19:02:28 -05:00
|
|
|
// Check pixel function
|
2019-06-08 12:24:49 -05:00
|
|
|
CHECK_EQUAL(true, f->CheckPixel(10, 112, 21, 191, 0, 255, 5));
|
|
|
|
|
CHECK_EQUAL(false, f->CheckPixel(10, 112, 0, 0, 0, 0, 5));
|
2019-05-31 19:02:28 -05:00
|
|
|
|
2012-07-09 01:44:36 -05:00
|
|
|
// Get frame 1
|
|
|
|
|
f = r.GetFrame(2);
|
|
|
|
|
|
|
|
|
|
// Get the next frame
|
2012-08-15 17:27:14 -05:00
|
|
|
pixels = f->GetPixels(10);
|
2015-06-01 00:20:14 -07:00
|
|
|
pixel_index = 112 * 4; // pixel 112 (4 bytes per pixel)
|
2012-07-09 01:44:36 -05:00
|
|
|
|
|
|
|
|
// Check image properties on scanline 10, pixel 112
|
2015-06-01 00:20:14 -07:00
|
|
|
CHECK_EQUAL(0, (int)pixels[pixel_index]);
|
|
|
|
|
CHECK_EQUAL(96, (int)pixels[pixel_index + 1]);
|
|
|
|
|
CHECK_EQUAL(188, (int)pixels[pixel_index + 2]);
|
|
|
|
|
CHECK_EQUAL(255, (int)pixels[pixel_index + 3]);
|
2012-07-09 01:44:36 -05:00
|
|
|
|
2019-05-31 19:02:28 -05:00
|
|
|
// Check pixel function
|
2019-06-08 12:45:13 -05:00
|
|
|
CHECK_EQUAL(true, f->CheckPixel(10, 112, 0, 96, 188, 255, 5));
|
|
|
|
|
CHECK_EQUAL(false, f->CheckPixel(10, 112, 0, 0, 0, 0, 5));
|
2019-05-31 19:02:28 -05:00
|
|
|
|
2014-04-03 22:35:25 -05:00
|
|
|
// Close reader
|
|
|
|
|
r.Close();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(FFmpegReader_Seek)
|
|
|
|
|
{
|
|
|
|
|
// Create a reader
|
2015-09-28 22:05:50 -05:00
|
|
|
stringstream path;
|
|
|
|
|
path << TEST_MEDIA_PATH << "sintel_trailer-720p.mp4";
|
|
|
|
|
FFmpegReader r(path.str());
|
2014-04-03 22:35:25 -05:00
|
|
|
r.Open();
|
|
|
|
|
|
|
|
|
|
// Get frame
|
2017-08-20 17:37:39 -05:00
|
|
|
std::shared_ptr<Frame> f = r.GetFrame(1);
|
2014-04-03 22:35:25 -05:00
|
|
|
CHECK_EQUAL(1, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(300);
|
|
|
|
|
CHECK_EQUAL(300, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(301);
|
|
|
|
|
CHECK_EQUAL(301, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(315);
|
|
|
|
|
CHECK_EQUAL(315, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(275);
|
|
|
|
|
CHECK_EQUAL(275, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(270);
|
|
|
|
|
CHECK_EQUAL(270, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(500);
|
|
|
|
|
CHECK_EQUAL(500, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(100);
|
|
|
|
|
CHECK_EQUAL(100, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(600);
|
|
|
|
|
CHECK_EQUAL(600, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(1);
|
|
|
|
|
CHECK_EQUAL(1, f->number);
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(700);
|
|
|
|
|
CHECK_EQUAL(700, f->number);
|
|
|
|
|
|
2012-07-09 01:44:36 -05:00
|
|
|
// Close reader
|
|
|
|
|
r.Close();
|
|
|
|
|
|
|
|
|
|
}
|
2014-04-03 22:35:25 -05:00
|
|
|
|
2015-02-19 01:03:22 -06:00
|
|
|
TEST(FFmpegReader_Multiple_Open_and_Close)
|
|
|
|
|
{
|
|
|
|
|
// Create a reader
|
2015-09-28 22:05:50 -05:00
|
|
|
stringstream path;
|
|
|
|
|
path << TEST_MEDIA_PATH << "sintel_trailer-720p.mp4";
|
|
|
|
|
FFmpegReader r(path.str());
|
2015-02-19 01:03:22 -06:00
|
|
|
r.Open();
|
|
|
|
|
|
|
|
|
|
// Get frame that requires a seek
|
2017-08-20 17:37:39 -05:00
|
|
|
std::shared_ptr<Frame> f = r.GetFrame(1200);
|
2015-02-19 01:03:22 -06:00
|
|
|
CHECK_EQUAL(1200, f->number);
|
|
|
|
|
|
|
|
|
|
// Close and Re-open the reader
|
|
|
|
|
r.Close();
|
|
|
|
|
r.Open();
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(1);
|
|
|
|
|
CHECK_EQUAL(1, f->number);
|
|
|
|
|
f = r.GetFrame(250);
|
|
|
|
|
CHECK_EQUAL(250, f->number);
|
|
|
|
|
|
|
|
|
|
// Close and Re-open the reader
|
|
|
|
|
r.Close();
|
|
|
|
|
r.Open();
|
|
|
|
|
|
|
|
|
|
// Get frame
|
|
|
|
|
f = r.GetFrame(750);
|
|
|
|
|
CHECK_EQUAL(750, f->number);
|
|
|
|
|
f = r.GetFrame(1000);
|
|
|
|
|
CHECK_EQUAL(1000, f->number);
|
|
|
|
|
|
|
|
|
|
// Close reader
|
|
|
|
|
r.Close();
|
|
|
|
|
}
|
|
|
|
|
|