X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fstream_test.cc;h=1cd7e4a4270f60144ebd706cc15468c9193710e6;hb=034feb503b0a38eb82c21ae8d9f83522fc63a25c;hp=4d97e82afbebda8e7de70b050053df2175d5476c;hpb=a0856e3fbef17f24073b01cb96be6bbcb229ecbc;p=dcpomatic.git diff --git a/test/stream_test.cc b/test/stream_test.cc index 4d97e82af..1cd7e4a42 100644 --- a/test/stream_test.cc +++ b/test/stream_test.cc @@ -17,38 +17,67 @@ */ +#include +#include +#include +#include "lib/ffmpeg_content.h" +#include "lib/film.h" + +using std::pair; +using std::list; +using boost::shared_ptr; + BOOST_AUTO_TEST_CASE (stream_test) { -#if 0 - FFmpegAudioStream a ("ffmpeg 4 44100 1 hello there world", boost::optional (1)); - BOOST_CHECK_EQUAL (a.id(), 4); - BOOST_CHECK_EQUAL (a.sample_rate(), 44100); - BOOST_CHECK_EQUAL (a.channel_layout(), 1); - BOOST_CHECK_EQUAL (a.name(), "hello there world"); - BOOST_CHECK_EQUAL (a.to_string(), "ffmpeg 4 44100 1 hello there world"); - - SndfileStream e ("external 44100 1", boost::optional (1)); - BOOST_CHECK_EQUAL (e.sample_rate(), 44100); - BOOST_CHECK_EQUAL (e.channel_layout(), 1); - BOOST_CHECK_EQUAL (e.to_string(), "external 44100 1"); - - SubtitleStream s ("5 a b c", boost::optional (1)); - BOOST_CHECK_EQUAL (s.id(), 5); - BOOST_CHECK_EQUAL (s.name(), "a b c"); - - shared_ptr ff = audio_stream_factory ("ffmpeg 4 44100 1 hello there world", boost::optional (1)); - shared_ptr cff = dynamic_pointer_cast (ff); - BOOST_CHECK (cff); - BOOST_CHECK_EQUAL (cff->id(), 4); - BOOST_CHECK_EQUAL (cff->sample_rate(), 44100); - BOOST_CHECK_EQUAL (cff->channel_layout(), 1); - BOOST_CHECK_EQUAL (cff->name(), "hello there world"); - BOOST_CHECK_EQUAL (cff->to_string(), "ffmpeg 4 44100 1 hello there world"); - - shared_ptr fe = audio_stream_factory ("external 44100 1", boost::optional (1)); - BOOST_CHECK_EQUAL (fe->sample_rate(), 44100); - BOOST_CHECK_EQUAL (fe->channel_layout(), 1); - BOOST_CHECK_EQUAL (fe->to_string(), "external 44100 1"); -#endif + xmlpp::Document doc; + xmlpp::Element* 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"); + mapping->add_child("ContentChannels")->add_child_text ("2"); + { + /* L -> L */ + xmlpp::Element* 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"); + 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"); + 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"); + 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.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, dcp::LEFT), 1); + BOOST_CHECK_EQUAL (a.mapping.get (0, dcp::RIGHT), 0); + BOOST_CHECK_EQUAL (a.mapping.get (0, dcp::CENTRE), 1); + BOOST_CHECK_EQUAL (a.mapping.get (1, dcp::LEFT), 0); + BOOST_CHECK_EQUAL (a.mapping.get (1, dcp::RIGHT), 1); + BOOST_CHECK_EQUAL (a.mapping.get (1, dcp::CENTRE), 1); }