/* -*- Mode: c++ -*- */ /*************************************************************************** * domloadertest.cc * * Sun Jun 10 17:48:04 CEST 2018 * Copyright 2018 Bent Bisballe Nyeng * deva@aasimon.org ****************************************************************************/ /* * This file is part of DrumGizmo. * * DrumGizmo is free software; you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * DrumGizmo 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with DrumGizmo; 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 "scopedfile.h" class DOMLoaderTest : public CppUnit::TestFixture { CPPUNIT_TEST_SUITE(DOMLoaderTest); CPPUNIT_TEST(testTest); CPPUNIT_TEST_SUITE_END(); Settings settings; Random random; public: void setUp() { } void tearDown() { } //! This just creates some drumkit. void testTest() { ScopedFile scoped_instrument_file1( "\n" \ "\n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ ""); ScopedFile scoped_instrument_file2( "\n" \ "\n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ ""); ScopedFile scoped_file( std::string( "\n" \ "\n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ "")); DrumKit drumkit; DrumkitDOM drumkitdom; std::vector instrumentdoms; CPPUNIT_ASSERT(parseDrumkitFile(scoped_file.filename(), drumkitdom)); for(const auto& ref: drumkitdom.instruments) { instrumentdoms.emplace_back(); CPPUNIT_ASSERT(parseInstrumentFile(ref.file, instrumentdoms.back())); } DOMLoader domloader(settings, random); CPPUNIT_ASSERT(domloader.loadDom(drumkitdom, instrumentdoms, drumkit)); // // Drumkit: // CPPUNIT_ASSERT_EQUAL(std::size_t(2), drumkit.instruments.size()); CPPUNIT_ASSERT_EQUAL(std::size_t(4), drumkit.channels.size()); CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), drumkit.channels[0].name); CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), drumkit.channels[1].name); CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), drumkit.channels[2].name); CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), drumkit.channels[3].name); CPPUNIT_ASSERT_EQUAL(std::string("CrocellKit"), drumkit._name); CPPUNIT_ASSERT_EQUAL(std::string("my description"), drumkit._description); CPPUNIT_ASSERT_EQUAL(std::size_t(48000), drumkit._samplerate); CPPUNIT_ASSERT(VersionStr("2.0.0") == drumkit._version); // // Instrument1 'Snare1': // { auto& instrument = *drumkit.instruments[0]; CPPUNIT_ASSERT_EQUAL(std::string(""), instrument._group); CPPUNIT_ASSERT_EQUAL(std::string("Snare"), instrument._name); CPPUNIT_ASSERT_EQUAL(std::string(""), instrument._description); CPPUNIT_ASSERT(VersionStr("2.0.0") == instrument.version); // NOTE: instrument.samples are the sample map belonging to version 1.0 CPPUNIT_ASSERT_EQUAL(std::size_t(2), instrument.samplelist.size()); { const auto& sample = *instrument.samplelist[0]; CPPUNIT_ASSERT_EQUAL(std::string("Snare-1"), sample.name); CPPUNIT_ASSERT_EQUAL(0.00985718f, sample.power); CPPUNIT_ASSERT_EQUAL(std::size_t(4), sample.audiofiles.size()); for(const auto& audiofile : sample.audiofiles) { CPPUNIT_ASSERT_EQUAL(std::string("/tmp/1-Snare.wav"), audiofile.second->filename); switch(audiofile.second->filechannel) { // NOTE: Channel numbers are zero based - they are 1 based in the xml case 0: CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), audiofile.second->instrument_channel->name); break; case 1: CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), audiofile.second->instrument_channel->name); break; case 11: CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), audiofile.second->instrument_channel->name); break; case 12: CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), audiofile.second->instrument_channel->name); break; default: CPPUNIT_ASSERT(false); break; } } } { const auto& sample = *instrument.samplelist[1]; CPPUNIT_ASSERT_EQUAL(std::string("Snare-2"), sample.name); CPPUNIT_ASSERT_EQUAL(0.0124808f, sample.power); CPPUNIT_ASSERT_EQUAL(std::size_t(4), sample.audiofiles.size()); for(const auto& audiofile : sample.audiofiles) { CPPUNIT_ASSERT_EQUAL(std::string("/tmp/2-Snare.wav"), audiofile.second->filename); switch(audiofile.second->filechannel) { // NOTE: Channel numbers are zero based - they are 1 based in the xml case 0: CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), audiofile.second->instrument_channel->name); break; case 1: CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), audiofile.second->instrument_channel->name); break; case 11: CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), audiofile.second->instrument_channel->name); break; case 12: CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), audiofile.second->instrument_channel->name); break; default: CPPUNIT_ASSERT(false); break; } } } } // // Instrument2 'Snare2': // { auto& instrument = *drumkit.instruments[1]; CPPUNIT_ASSERT_EQUAL(std::string(""), instrument._group); CPPUNIT_ASSERT_EQUAL(std::string("Snare"), instrument._name); CPPUNIT_ASSERT_EQUAL(std::string(""), instrument._description); CPPUNIT_ASSERT(VersionStr("2.0.0") == instrument.version); // NOTE: instrument.samples are the sample map belonging to version 1.0 CPPUNIT_ASSERT_EQUAL(std::size_t(2), instrument.samplelist.size()); { const auto& sample = *instrument.samplelist[0]; CPPUNIT_ASSERT_EQUAL(std::string("Snare-1"), sample.name); CPPUNIT_ASSERT_EQUAL(0.00985718f, sample.power); CPPUNIT_ASSERT_EQUAL(std::size_t(4), sample.audiofiles.size()); for(const auto& audiofile : sample.audiofiles) { CPPUNIT_ASSERT_EQUAL(std::string("/tmp/1-Snare.wav"), audiofile.second->filename); switch(audiofile.second->filechannel) { // NOTE: Channel numbers are zero based - they are 1 based in the xml case 0: CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), audiofile.second->instrument_channel->name); break; case 1: CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), audiofile.second->instrument_channel->name); break; case 11: CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), audiofile.second->instrument_channel->name); break; case 12: CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), audiofile.second->instrument_channel->name); break; default: CPPUNIT_ASSERT(false); break; } } } { const auto& sample = *instrument.samplelist[1]; CPPUNIT_ASSERT_EQUAL(std::string("Snare-2"), sample.name); CPPUNIT_ASSERT_EQUAL(0.0124808f, sample.power); CPPUNIT_ASSERT_EQUAL(std::size_t(4), sample.audiofiles.size()); for(const auto& audiofile : sample.audiofiles) { CPPUNIT_ASSERT_EQUAL(std::string("/tmp/2-Snare.wav"), audiofile.second->filename); switch(audiofile.second->filechannel) { // NOTE: Channel numbers are zero based - they are 1 based in the xml case 0: CPPUNIT_ASSERT_EQUAL(std::string("AmbLeft"), audiofile.second->instrument_channel->name); break; case 1: CPPUNIT_ASSERT_EQUAL(std::string("AmbRight"), audiofile.second->instrument_channel->name); break; case 11: CPPUNIT_ASSERT_EQUAL(std::string("SnareBottom"), audiofile.second->instrument_channel->name); break; case 12: CPPUNIT_ASSERT_EQUAL(std::string("SnareTop"), audiofile.second->instrument_channel->name); break; default: CPPUNIT_ASSERT(false); break; } } } } } }; // Registers the fixture into the 'registry' CPPUNIT_TEST_SUITE_REGISTRATION(DOMLoaderTest);