/* * Copyright (c) 2009-2011 John Glover, National University of Ireland, Maynooth * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program 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 * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */ #include #include #include #include #include #include #include #include "../src/simpl/base.h" #include "../src/simpl/exceptions.h" namespace Simpl { // --------------------------------------------------------------------------- // TestPeak // --------------------------------------------------------------------------- class TestPeak : public CPPUNIT_NS::TestCase { CPPUNIT_TEST_SUITE(TestPeak); CPPUNIT_TEST(test_constructor); CPPUNIT_TEST(test_is_free); CPPUNIT_TEST(test_is_start_of_partial); CPPUNIT_TEST_SUITE_END(); protected: static const double PRECISION = 0.001; Peak* peak; void test_constructor() { CPPUNIT_ASSERT_DOUBLES_EQUAL(peak->amplitude, 0.0, PRECISION); CPPUNIT_ASSERT_DOUBLES_EQUAL(peak->frequency, 0.0, PRECISION); CPPUNIT_ASSERT_DOUBLES_EQUAL(peak->phase, 0.0, PRECISION); CPPUNIT_ASSERT(peak->next_peak == NULL); CPPUNIT_ASSERT(peak->previous_peak == NULL); CPPUNIT_ASSERT(peak->partial_id == 0); CPPUNIT_ASSERT(peak->partial_position == 0); CPPUNIT_ASSERT(peak->frame_number == 0); } void test_is_start_of_partial() { CPPUNIT_ASSERT(peak->is_start_of_partial()); Peak* tmp = new Peak(); peak->previous_peak = tmp; CPPUNIT_ASSERT(!peak->is_start_of_partial()); peak->previous_peak = NULL; delete tmp; } void test_is_free() { peak->amplitude = 0.0; CPPUNIT_ASSERT(!peak->is_free()); peak->amplitude = 1.0; CPPUNIT_ASSERT(peak->is_free()); Peak* tmp = new Peak(); peak->next_peak = tmp; CPPUNIT_ASSERT(!peak->is_free()); CPPUNIT_ASSERT(!peak->is_free("forwards")); CPPUNIT_ASSERT(peak->is_free("backwards")); peak->next_peak = NULL; peak->previous_peak = tmp; CPPUNIT_ASSERT(peak->is_free()); CPPUNIT_ASSERT(peak->is_free("forwards")); CPPUNIT_ASSERT(!peak->is_free("backwards")); peak->previous_peak = NULL; delete tmp; CPPUNIT_ASSERT_THROW(peak->is_free("random_text"), InvalidArgument); } public: void setUp() { peak = new Peak(); } void tearDown() { delete peak; } }; // --------------------------------------------------------------------------- // TestFrame // --------------------------------------------------------------------------- class TestFrame : public CPPUNIT_NS::TestCase { CPPUNIT_TEST_SUITE(TestFrame); CPPUNIT_TEST(test_constructor); CPPUNIT_TEST(test_set_size); CPPUNIT_TEST(test_set_max_peaks); CPPUNIT_TEST(test_set_max_partials); CPPUNIT_TEST_SUITE_END(); protected: static const double PRECISION = 0.001; Frame* frame; void test_constructor() { CPPUNIT_ASSERT(frame->get_size() == 512); CPPUNIT_ASSERT(frame->audio.size() == 512); CPPUNIT_ASSERT(frame->synth.size() == 512); CPPUNIT_ASSERT(frame->residual.size() == 512); CPPUNIT_ASSERT(frame->synth_residual.size() == 512); CPPUNIT_ASSERT(frame->get_max_peaks() == 100); CPPUNIT_ASSERT(frame->peaks.size() == 100); CPPUNIT_ASSERT(frame->get_max_partials() == 100); CPPUNIT_ASSERT(frame->partials.size() == 100); } void test_set_size() { frame->set_size(1024); CPPUNIT_ASSERT(frame->get_size() == 1024); CPPUNIT_ASSERT(frame->audio.size() == 1024); CPPUNIT_ASSERT(frame->synth.size() == 1024); CPPUNIT_ASSERT(frame->residual.size() == 1024); CPPUNIT_ASSERT(frame->synth_residual.size() == 1024); frame->set_size(512); } void test_set_max_peaks() { frame->set_max_peaks(200); CPPUNIT_ASSERT(frame->get_max_peaks() == 200); CPPUNIT_ASSERT(frame->peaks.size() == 200); frame->set_max_peaks(100); } void test_set_max_partials() { frame->set_max_partials(200); CPPUNIT_ASSERT(frame->get_max_partials() == 200); CPPUNIT_ASSERT(frame->partials.size() == 200); frame->set_max_partials(100); } public: void setUp() { frame = new Frame(); } void tearDown() { delete frame; } }; } // end of namespace Simpl CPPUNIT_TEST_SUITE_REGISTRATION(Simpl::TestPeak); CPPUNIT_TEST_SUITE_REGISTRATION(Simpl::TestFrame); int main(int arg, char **argv) { CppUnit::TextTestRunner runner; runner.addTest(CppUnit::TestFactoryRegistry::getRegistry().makeTest()); return runner.run("", false); }