X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fstream_test.cc;h=a180739ab5f8e84fe9cd1223731824345d74263b;hb=ce73eaf7875a9a3326afcd839ad85eb95879c160;hp=6abcf6e22aedf95a0dec879a05746accf4a5d443;hpb=d867b45c8de7400c977d7d1f188936ba3399432e;p=dcpomatic.git diff --git a/test/stream_test.cc b/test/stream_test.cc index 6abcf6e22..a180739ab 100644 --- a/test/stream_test.cc +++ b/test/stream_test.cc @@ -1,83 +1,95 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2014 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic 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, + DCP-o-matic 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., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ -#include -#include -#include + +/** @test test/stream_test.cc + * @brief Some simple tests of FFmpegAudioStream. + */ + + +#include "lib/ffmpeg_audio_stream.h" #include "lib/ffmpeg_content.h" #include "lib/film.h" +#include +#include +LIBDCP_DISABLE_WARNINGS +#include +LIBDCP_ENABLE_WARNINGS +#include + -using std::pair; using std::list; -using boost::shared_ptr; +using std::pair; + BOOST_AUTO_TEST_CASE (stream_test) { xmlpp::Document doc; - xmlpp::Element* root = doc.create_root_node ("FFmpegAudioStream"); + auto root = doc.create_root_node("FFmpegAudioStream"); root->add_child("Name")->add_child_text ("hello there world"); root->add_child("Id")->add_child_text ("4"); root->add_child("FrameRate")->add_child_text ("44100"); root->add_child("Channels")->add_child_text ("2"); /* This is the state file version 5 description of the mapping */ - - xmlpp::Element* mapping = root->add_child("Mapping"); + + auto mapping = root->add_child("Mapping"); mapping->add_child("ContentChannels")->add_child_text ("2"); { /* L -> L */ - xmlpp::Element* map = mapping->add_child ("Map"); + auto map = mapping->add_child("Map"); map->add_child("ContentIndex")->add_child_text ("0"); map->add_child("DCP")->add_child_text ("0"); } { /* L -> C */ - xmlpp::Element* map = mapping->add_child ("Map"); + auto map = mapping->add_child("Map"); map->add_child("ContentIndex")->add_child_text ("0"); map->add_child("DCP")->add_child_text ("2"); } { /* R -> R */ - xmlpp::Element* map = mapping->add_child ("Map"); + auto map = mapping->add_child("Map"); map->add_child("ContentIndex")->add_child_text ("1"); map->add_child("DCP")->add_child_text ("1"); } { /* R -> C */ - xmlpp::Element* map = mapping->add_child ("Map"); + auto map = mapping->add_child("Map"); map->add_child("ContentIndex")->add_child_text ("1"); map->add_child("DCP")->add_child_text ("2"); } - - FFmpegAudioStream a (shared_ptr (new cxml::Node (root)), 5); - BOOST_CHECK_EQUAL (a.id, 4); - BOOST_CHECK_EQUAL (a.frame_rate, 44100); - BOOST_CHECK_EQUAL (a.channels, 2); + FFmpegAudioStream a (cxml::NodePtr (new cxml::Node (root)), 5); + + BOOST_CHECK_EQUAL (a.identifier(), "4"); + BOOST_CHECK_EQUAL (a.frame_rate(), 44100); + BOOST_CHECK_EQUAL (a.channels(), 2); BOOST_CHECK_EQUAL (a.name, "hello there world"); - BOOST_CHECK_EQUAL (a.mapping.content_channels(), 2); - - BOOST_CHECK_EQUAL (a.mapping.get (0, libdcp::LEFT), 1); - BOOST_CHECK_EQUAL (a.mapping.get (0, libdcp::RIGHT), 0); - BOOST_CHECK_EQUAL (a.mapping.get (0, libdcp::CENTRE), 1); - BOOST_CHECK_EQUAL (a.mapping.get (1, libdcp::LEFT), 0); - BOOST_CHECK_EQUAL (a.mapping.get (1, libdcp::RIGHT), 1); - BOOST_CHECK_EQUAL (a.mapping.get (1, libdcp::CENTRE), 1); + BOOST_CHECK_EQUAL (a.mapping().input_channels(), 2); + + BOOST_CHECK_EQUAL (a.mapping().get(0, dcp::Channel::LEFT), 1); + BOOST_CHECK_EQUAL (a.mapping().get(0, dcp::Channel::RIGHT), 0); + BOOST_CHECK_EQUAL (a.mapping().get(0, dcp::Channel::CENTRE), 1); + BOOST_CHECK_EQUAL (a.mapping().get(1, dcp::Channel::LEFT), 0); + BOOST_CHECK_EQUAL (a.mapping().get(1, dcp::Channel::RIGHT), 1); + BOOST_CHECK_EQUAL (a.mapping().get(1, dcp::Channel::CENTRE), 1); }