/* -*- Mode: c++ -*- */ /*************************************************************************** * dgxmlparsertest.cc * * Sat Jun 9 11:37:19 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 "scopedfile.h" class DGXmlParserTest : public uUnit { public: DGXmlParserTest() { uUNIT_TEST(DGXmlParserTest::instrumentParserTest_v1); uUNIT_TEST(DGXmlParserTest::instrumentParserTest_v2); uUNIT_TEST(DGXmlParserTest::drumkitParserTest); } void instrumentParserTest_v1() { ScopedFile scoped_file( "\n" \ "\n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " " \ " " \ " " \ " " \ " " \ " " \ ""); InstrumentDOM dom; uUNIT_ASSERT(probeInstrumentFile(scoped_file.filename())); uUNIT_ASSERT(parseInstrumentFile(scoped_file.filename(), dom)); uUNIT_ASSERT_EQUAL(std::string("Snare"), dom.name); uUNIT_ASSERT_EQUAL(std::string("1.0"), dom.version); uUNIT_ASSERT_EQUAL(std::string("A nice snare"), dom.description); uUNIT_ASSERT_EQUAL(std::size_t(2), dom.samples.size()); { const auto& s = dom.samples[0]; uUNIT_ASSERT_EQUAL(std::string("Snare-1"), s.name); uUNIT_ASSERT_EQUAL(std::size_t(4), s.audiofiles.size()); uUNIT_ASSERT_EQUAL(std::string("AmbLeft"), s.audiofiles[0].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("1-Snare-1.wav"), s.audiofiles[0].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[0].filechannel); uUNIT_ASSERT_EQUAL(std::string("AmbRight"), s.audiofiles[1].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("1-Snare-2.wav"), s.audiofiles[1].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[1].filechannel); uUNIT_ASSERT_EQUAL(std::string("SnareBottom"), s.audiofiles[2].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("1-Snare-3.wav"), s.audiofiles[2].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[2].filechannel); uUNIT_ASSERT_EQUAL(std::string("SnareTop"), s.audiofiles[3].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("1-Snare-4.wav"), s.audiofiles[3].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[3].filechannel); } { const auto& s = dom.samples[1]; uUNIT_ASSERT_EQUAL(std::string("Snare-2"), s.name); uUNIT_ASSERT_EQUAL(std::size_t(4), s.audiofiles.size()); uUNIT_ASSERT_EQUAL(std::string("AmbLeft"), s.audiofiles[0].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("2-Snare-1.wav"), s.audiofiles[0].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[0].filechannel); uUNIT_ASSERT_EQUAL(std::string("AmbRight"), s.audiofiles[1].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("2-Snare-2.wav"), s.audiofiles[1].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[1].filechannel); uUNIT_ASSERT_EQUAL(std::string("SnareBottom"), s.audiofiles[2].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("2-Snare-3.wav"), s.audiofiles[2].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[2].filechannel); uUNIT_ASSERT_EQUAL(std::string("SnareTop"), s.audiofiles[3].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("2-Snare-4.wav"), s.audiofiles[3].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[3].filechannel); } uUNIT_ASSERT_EQUAL(std::size_t(0), dom.instrument_channels.size()); uUNIT_ASSERT_EQUAL(std::size_t(2), dom.velocities.size()); { const auto& velocity = dom.velocities[0]; uUNIT_ASSERT_EQUAL(0.0, velocity.lower); uUNIT_ASSERT_EQUAL(0.6, velocity.upper); uUNIT_ASSERT_EQUAL(std::size_t(2), velocity.samplerefs.size()); uUNIT_ASSERT_EQUAL(std::string("Snare-1"), velocity.samplerefs[0].name); uUNIT_ASSERT_EQUAL(0.6, velocity.samplerefs[0].probability); uUNIT_ASSERT_EQUAL(std::string("Snare-2"), velocity.samplerefs[1].name); uUNIT_ASSERT_EQUAL(0.4, velocity.samplerefs[1].probability); } { const auto& velocity = dom.velocities[1]; uUNIT_ASSERT_EQUAL(0.6, velocity.lower); uUNIT_ASSERT_EQUAL(1.0, velocity.upper); uUNIT_ASSERT_EQUAL(std::size_t(2), velocity.samplerefs.size()); uUNIT_ASSERT_EQUAL(std::string("Snare-2"), velocity.samplerefs[0].name); uUNIT_ASSERT_EQUAL(0.4, velocity.samplerefs[0].probability); uUNIT_ASSERT_EQUAL(std::string("Snare-1"), velocity.samplerefs[1].name); uUNIT_ASSERT_EQUAL(0.6, velocity.samplerefs[1].probability); } } void instrumentParserTest_v2() { ScopedFile scoped_file( "\n" \ "\n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ ""); InstrumentDOM dom; uUNIT_ASSERT(probeInstrumentFile(scoped_file.filename())); uUNIT_ASSERT(parseInstrumentFile(scoped_file.filename(), dom)); uUNIT_ASSERT_EQUAL(std::string("Snare"), dom.name); uUNIT_ASSERT_EQUAL(std::string("2.0"), dom.version); uUNIT_ASSERT_EQUAL(std::string("A nice snare"), dom.description); uUNIT_ASSERT_EQUAL(std::size_t(2), dom.samples.size()); { const auto& s = dom.samples[0]; uUNIT_ASSERT_EQUAL(std::string("Snare-1"), s.name); uUNIT_ASSERT_EQUAL(0.00985718, s.power); uUNIT_ASSERT_EQUAL(std::size_t(4), s.audiofiles.size()); uUNIT_ASSERT_EQUAL(std::string("AmbLeft"), s.audiofiles[0].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("1-Snare.wav"), s.audiofiles[0].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[0].filechannel); uUNIT_ASSERT_EQUAL(std::string("AmbRight"), s.audiofiles[1].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("1-Snare.wav"), s.audiofiles[1].file); uUNIT_ASSERT_EQUAL(std::size_t(2), s.audiofiles[1].filechannel); uUNIT_ASSERT_EQUAL(std::string("SnareBottom"), s.audiofiles[2].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("1-Snare.wav"), s.audiofiles[2].file); uUNIT_ASSERT_EQUAL(std::size_t(12), s.audiofiles[2].filechannel); uUNIT_ASSERT_EQUAL(std::string("SnareTop"), s.audiofiles[3].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("1-Snare.wav"), s.audiofiles[3].file); uUNIT_ASSERT_EQUAL(std::size_t(13), s.audiofiles[3].filechannel); } { const auto& s = dom.samples[1]; uUNIT_ASSERT_EQUAL(std::string("Snare-2"), s.name); uUNIT_ASSERT_EQUAL(0.0124808, s.power); uUNIT_ASSERT_EQUAL(std::size_t(4), s.audiofiles.size()); uUNIT_ASSERT_EQUAL(std::string("AmbLeft"), s.audiofiles[0].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("2-Snare.wav"), s.audiofiles[0].file); uUNIT_ASSERT_EQUAL(std::size_t(1), s.audiofiles[0].filechannel); uUNIT_ASSERT_EQUAL(std::string("AmbRight"), s.audiofiles[1].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("2-Snare.wav"), s.audiofiles[1].file); uUNIT_ASSERT_EQUAL(std::size_t(2), s.audiofiles[1].filechannel); uUNIT_ASSERT_EQUAL(std::string("SnareBottom"), s.audiofiles[2].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("2-Snare.wav"), s.audiofiles[2].file); uUNIT_ASSERT_EQUAL(std::size_t(12), s.audiofiles[2].filechannel); uUNIT_ASSERT_EQUAL(std::string("SnareTop"), s.audiofiles[3].instrument_channel); uUNIT_ASSERT_EQUAL(std::string("2-Snare.wav"), s.audiofiles[3].file); uUNIT_ASSERT_EQUAL(std::size_t(13), s.audiofiles[3].filechannel); } uUNIT_ASSERT_EQUAL(std::size_t(3), dom.instrument_channels.size()); uUNIT_ASSERT_EQUAL(std::string("AmbLeft"), dom.instrument_channels[0].name); uUNIT_ASSERT(main_state_t::is_main == dom.instrument_channels[0].main); uUNIT_ASSERT_EQUAL(std::string("AmbRight"), dom.instrument_channels[1].name); uUNIT_ASSERT(main_state_t::is_not_main == dom.instrument_channels[1].main); uUNIT_ASSERT_EQUAL(std::string("SnareBottom"), dom.instrument_channels[2].name); uUNIT_ASSERT(main_state_t::unset == dom.instrument_channels[2].main); uUNIT_ASSERT_EQUAL(std::size_t(0), dom.velocities.size()); } void drumkitParserTest() { ScopedFile scoped_file( "\n" \ "\n" \ " \n" \ " 1.2.3\n" \ " Test Kit\n" \ " \n" \ " This is the description of the drumkit\n" \ " Creative Commons\n" \ " These are general notes\n" \ " Author of the drumkit\n" \ " author@email.org\n" \ " http://www.drumgizmo.org\n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ " \n" \ ""); DrumkitDOM dom; uUNIT_ASSERT(probeDrumkitFile(scoped_file.filename())); uUNIT_ASSERT(parseDrumkitFile(scoped_file.filename(), dom)); uUNIT_ASSERT_EQUAL(std::string("2.0"), dom.version); uUNIT_ASSERT_EQUAL(48000.0, dom.samplerate); uUNIT_ASSERT_EQUAL(std::string("1.2.3"), dom.metadata.version); uUNIT_ASSERT_EQUAL(std::string("Test Kit"), dom.metadata.title); uUNIT_ASSERT_EQUAL(std::string("LogoFile.png"), dom.metadata.logo); uUNIT_ASSERT_EQUAL(std::string("This is the description of the drumkit"), dom.metadata.description); uUNIT_ASSERT_EQUAL(std::string("Creative Commons"), dom.metadata.license); uUNIT_ASSERT_EQUAL(std::string("These are general notes"), dom.metadata.notes); uUNIT_ASSERT_EQUAL(std::string("Author of the drumkit"), dom.metadata.author); uUNIT_ASSERT_EQUAL(std::string("author@email.org"), dom.metadata.email); uUNIT_ASSERT_EQUAL(std::string("http://www.drumgizmo.org"), dom.metadata.website); uUNIT_ASSERT_EQUAL(std::string("DrumkitImage.png"), dom.metadata.image); uUNIT_ASSERT_EQUAL(std::string("DrumkitImageClickMap.png"), dom.metadata.image_map); uUNIT_ASSERT_EQUAL(std::size_t(2), dom.metadata.clickmaps.size()); uUNIT_ASSERT_EQUAL(std::string("ff08a2"), dom.metadata.clickmaps[0].colour); uUNIT_ASSERT_EQUAL(std::string("China"), dom.metadata.clickmaps[0].instrument); uUNIT_ASSERT_EQUAL(std::string("a218d7"), dom.metadata.clickmaps[1].colour); uUNIT_ASSERT_EQUAL(std::string("HihatClosed"), dom.metadata.clickmaps[1].instrument); uUNIT_ASSERT_EQUAL(std::size_t(2), dom.instruments.size()); { const auto& instr = dom.instruments[0]; uUNIT_ASSERT_EQUAL(std::string("Snare1"), instr.name); uUNIT_ASSERT_EQUAL(std::string("foo.wav"), instr.file); uUNIT_ASSERT_EQUAL(std::string("somegroup"), instr.group); uUNIT_ASSERT_EQUAL(std::size_t(4), instr.channel_map.size()); uUNIT_ASSERT_EQUAL(std::string("AmbLeft-in"), instr.channel_map[0].in); uUNIT_ASSERT_EQUAL(std::string("AmbRight-in"), instr.channel_map[1].in); uUNIT_ASSERT_EQUAL(std::string("SnareTop-in"), instr.channel_map[2].in); uUNIT_ASSERT_EQUAL(std::string("SnareBottom-in"), instr.channel_map[3].in); uUNIT_ASSERT_EQUAL(std::string("AmbLeft"), instr.channel_map[0].out); uUNIT_ASSERT_EQUAL(std::string("AmbRight"), instr.channel_map[1].out); uUNIT_ASSERT_EQUAL(std::string("SnareTop"), instr.channel_map[2].out); uUNIT_ASSERT_EQUAL(std::string("SnareBottom"), instr.channel_map[3].out); uUNIT_ASSERT(main_state_t::is_main == instr.channel_map[0].main); uUNIT_ASSERT(main_state_t::is_main == instr.channel_map[1].main); uUNIT_ASSERT(main_state_t::unset == instr.channel_map[2].main); uUNIT_ASSERT(main_state_t::unset == instr.channel_map[3].main); } { const auto& instr = dom.instruments[1]; uUNIT_ASSERT_EQUAL(std::string("Snare2"), instr.name); uUNIT_ASSERT_EQUAL(std::string("bar.wav"), instr.file); uUNIT_ASSERT_EQUAL(std::string(""), instr.group); uUNIT_ASSERT_EQUAL(std::size_t(4), instr.channel_map.size()); uUNIT_ASSERT_EQUAL(std::string("AmbLeft2-in"), instr.channel_map[0].in); uUNIT_ASSERT_EQUAL(std::string("AmbRight2-in"), instr.channel_map[1].in); uUNIT_ASSERT_EQUAL(std::string("SnareTop2-in"), instr.channel_map[2].in); uUNIT_ASSERT_EQUAL(std::string("SnareBottom2-in"), instr.channel_map[3].in); uUNIT_ASSERT_EQUAL(std::string("AmbLeft"), instr.channel_map[0].out); uUNIT_ASSERT_EQUAL(std::string("AmbRight"), instr.channel_map[1].out); uUNIT_ASSERT_EQUAL(std::string("SnareTop"), instr.channel_map[2].out); uUNIT_ASSERT_EQUAL(std::string("SnareBottom"), instr.channel_map[3].out); uUNIT_ASSERT(main_state_t::is_not_main == instr.channel_map[0].main); uUNIT_ASSERT(main_state_t::is_not_main == instr.channel_map[1].main); uUNIT_ASSERT(main_state_t::unset == instr.channel_map[2].main); uUNIT_ASSERT(main_state_t::unset == instr.channel_map[3].main); } uUNIT_ASSERT_EQUAL(std::size_t(4), dom.channels.size()); uUNIT_ASSERT_EQUAL(std::string("AmbLeft"), dom.channels[0].name); uUNIT_ASSERT_EQUAL(std::string("AmbRight"), dom.channels[1].name); uUNIT_ASSERT_EQUAL(std::string("SnareTop"), dom.channels[2].name); uUNIT_ASSERT_EQUAL(std::string("SnareBottom"), dom.channels[3].name); } }; // Registers the fixture into the 'registry' static DGXmlParserTest test;