X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fstream_test.cc;h=fe64e147e3b8b48eeb2e24a33a70cbc02c8e86cc;hb=dc5e11944a30a9d381dc0e67cf657c5f2cb65845;hp=a95eb708c4324885fe20e478c000ffa357894eb3;hpb=ae3b01aab7ef9e6101a7a1a11c511706148a9f1e;p=dcpomatic.git diff --git a/test/stream_test.cc b/test/stream_test.cc index a95eb708c..fe64e147e 100644 --- a/test/stream_test.cc +++ b/test/stream_test.cc @@ -1,25 +1,40 @@ /* - 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 . */ +/** @test test/stream_test.cc + * @brief Some simple tests of FFmpegAudioStream. + */ + +#include "lib/film.h" +#include "lib/ffmpeg_content.h" +#include "lib/ffmpeg_audio_stream.h" #include +#include +LIBDCP_DISABLE_WARNINGS +#include +LIBDCP_ENABLE_WARNINGS +#include using std::pair; +using std::list; +using std::shared_ptr; BOOST_AUTO_TEST_CASE (stream_test) { @@ -29,6 +44,9 @@ BOOST_AUTO_TEST_CASE (stream_test) 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"); mapping->add_child("ContentChannels")->add_child_text ("2"); { @@ -55,33 +73,20 @@ BOOST_AUTO_TEST_CASE (stream_test) map->add_child("ContentIndex")->add_child_text ("1"); map->add_child("DCP")->add_child_text ("2"); } - - FFmpegAudioStream a (shared_ptr (new cxml::Node (root))); - BOOST_CHECK_EQUAL (a.id, 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.content_to_dcp().size(), 4); - - list > m = a.mapping.content_to_dcp (); - list >::iterator i = m.begin(); + FFmpegAudioStream a (cxml::NodePtr (new cxml::Node (root)), 5); - BOOST_CHECK_EQUAL (i->first, 0); - BOOST_CHECK_EQUAL (i->second, libdcp::LEFT); - ++i; - - BOOST_CHECK_EQUAL (i->first, 0); - BOOST_CHECK_EQUAL (i->second, libdcp::CENTRE); - ++i; - - BOOST_CHECK_EQUAL (i->first, 1); - BOOST_CHECK_EQUAL (i->second, libdcp::RIGHT); - ++i; + 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().input_channels(), 2); - BOOST_CHECK_EQUAL (i->first, 1); - BOOST_CHECK_EQUAL (i->second, libdcp::CENTRE); - ++i; + 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); }