Paul Davis
30b087ab3d
Generated by tools/f2s. Some hand-editing will be required in a few places to fix up comments related to timecode and video in order to keep the legible
55 lines
1.0 KiB
C++
55 lines
1.0 KiB
C++
#include "tests/utils.h"
|
|
|
|
#include "audiographer/general/peak_reader.h"
|
|
|
|
using namespace AudioGrapher;
|
|
|
|
class PeakReaderTest : public CppUnit::TestFixture
|
|
{
|
|
CPPUNIT_TEST_SUITE (PeakReaderTest);
|
|
CPPUNIT_TEST (testProcess);
|
|
CPPUNIT_TEST_SUITE_END ();
|
|
|
|
public:
|
|
void setUp()
|
|
{
|
|
samples = 128;
|
|
random_data = TestUtils::init_random_data(samples);
|
|
}
|
|
|
|
void tearDown()
|
|
{
|
|
delete [] random_data;
|
|
}
|
|
|
|
void testProcess()
|
|
{
|
|
reader.reset (new PeakReader());
|
|
ProcessContext<float> c (random_data, samples, 1);
|
|
|
|
float peak = 1.5;
|
|
random_data[10] = peak;
|
|
reader->process (c);
|
|
CPPUNIT_ASSERT_EQUAL(peak, reader->get_peak());
|
|
|
|
peak = 2.0;
|
|
random_data[10] = peak;
|
|
reader->process (c);
|
|
CPPUNIT_ASSERT_EQUAL(peak, reader->get_peak());
|
|
|
|
peak = -2.1;
|
|
random_data[10] = peak;
|
|
reader->process (c);
|
|
float expected = fabs(peak);
|
|
CPPUNIT_ASSERT_EQUAL(expected, reader->get_peak());
|
|
}
|
|
|
|
private:
|
|
boost::shared_ptr<PeakReader> reader;
|
|
|
|
float * random_data;
|
|
samplecnt_t samples;
|
|
};
|
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION (PeakReaderTest);
|