X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fstream_test.cc;h=800bbd049c0c64cc1401378b39d4fca963d40a36;hb=fa61fc99549264810e17fcd35abffe9e8ddab5b2;hp=4d97e82afbebda8e7de70b050053df2175d5476c;hpb=a183c1776cfd020a37d028ebb0f641352f49697b;p=dcpomatic.git diff --git a/test/stream_test.cc b/test/stream_test.cc index 4d97e82af..800bbd049 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,38 +17,72 @@ */ +/** @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; +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 (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().input_channels(), 2); + + 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); }