X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fstream_test.cc;h=ec211a929772a15a89d6307a4ea2f4c4f33df1f6;hb=0df83d7ba261cdbb5be62db34dae7b972e05ddd9;hp=b56f133c7df1af8efb817a8231c0b78728833eb1;hpb=59404039618db5d70a2f8fc0cb8c49ae4f8ce527;p=dcpomatic.git diff --git a/test/stream_test.cc b/test/stream_test.cc index b56f133c7..ec211a929 100644 --- a/test/stream_test.cc +++ b/test/stream_test.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2014 Carl Hetherington 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 @@ -17,10 +17,16 @@ */ +/** @test test/stream_test.cc + * @brief Some simple tests of FFmpegAudioStream. + */ + #include #include #include #include "lib/ffmpeg_content.h" +#include "lib/ffmpeg_audio_stream.h" +#include "lib/film.h" using std::pair; using std::list; @@ -34,6 +40,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"); { @@ -60,33 +69,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, static_cast (dcp::LEFT)), 1); + BOOST_CHECK_EQUAL (a.mapping().get (0, static_cast (dcp::RIGHT)), 0); + BOOST_CHECK_EQUAL (a.mapping().get (0, static_cast (dcp::CENTRE)), 1); + BOOST_CHECK_EQUAL (a.mapping().get (1, static_cast (dcp::LEFT)), 0); + BOOST_CHECK_EQUAL (a.mapping().get (1, static_cast (dcp::RIGHT)), 1); + BOOST_CHECK_EQUAL (a.mapping().get (1, static_cast (dcp::CENTRE)), 1); }