X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fdcp_subtitle_test.cc;h=d7d55e9c06bae5a3ac471fd362e81ce6a49677cd;hb=8fdfc18162ffee3401c64e676481b5e89480ac83;hp=e8a5a4c04cb25d0ae08b4c590fcee48e74faa48c;hpb=5ce9c7026366d82233e8852b9b949362ed2f6191;p=dcpomatic.git diff --git a/test/dcp_subtitle_test.cc b/test/dcp_subtitle_test.cc index e8a5a4c04..d7d55e9c0 100644 --- a/test/dcp_subtitle_test.cc +++ b/test/dcp_subtitle_test.cc @@ -24,11 +24,15 @@ #include #include "lib/film.h" #include "lib/dcp_subtitle_content.h" +#include "lib/dcp_content.h" #include "lib/ratio.h" +#include "lib/dcp_decoder.h" #include "lib/dcp_content_type.h" #include "test.h" +#include using std::cout; +using std::list; using boost::shared_ptr; /** Test pass-through of a very simple DCP subtitle file */ @@ -51,3 +55,44 @@ BOOST_AUTO_TEST_CASE (dcp_subtitle_test) check_dcp ("test/data/dcp_subtitle_test", film->dir (film->dcp_name ())); } + +/** Test parsing of a subtitle within an existing DCP */ +BOOST_AUTO_TEST_CASE (dcp_subtitle_within_dcp_test) +{ + shared_ptr film = new_test_film ("dcp_subtitle_within_dcp_test"); + film->set_container (Ratio::from_id ("185")); + film->set_dcp_content_type (DCPContentType::from_isdcf_name ("TLR")); + film->set_name ("frobozz"); + shared_ptr content (new DCPContent (film, private_data / "JourneyToJah_TLR-1_F_EN-DE-FR_CH_51_2K_LOK_20140225_DGL_SMPTE_OV")); + film->examine_and_add_content (content); + wait_for_jobs (); + + shared_ptr decoder (new DCPDecoder (content, false)); + + list ctp = decoder->text_subtitles_during ( + ContentTimePeriod ( + ContentTime::from_seconds (25), + ContentTime::from_seconds (26) + ), + true + ); + + BOOST_REQUIRE_EQUAL (ctp.size(), 2); + BOOST_CHECK_EQUAL (ctp.front().from, ContentTime::from_seconds (25 + 12 * 0.04)); + BOOST_CHECK_EQUAL (ctp.front().to, ContentTime::from_seconds (26 + 4 * 0.04)); + BOOST_CHECK_EQUAL (ctp.back().from, ContentTime::from_seconds (25 + 12 * 0.04)); + BOOST_CHECK_EQUAL (ctp.back().to, ContentTime::from_seconds (26 + 4 * 0.04)); + + list subs = decoder->get_text_subtitles ( + ContentTimePeriod ( + ContentTime::from_seconds (25), + ContentTime::from_seconds (26) + ), + true + ); + + BOOST_REQUIRE_EQUAL (subs.size(), 1); + BOOST_REQUIRE_EQUAL (subs.front().subs.size(), 2); + BOOST_CHECK_EQUAL (subs.front().subs.front().text(), "Noch mal."); + BOOST_CHECK_EQUAL (subs.front().subs.back().text(), "Encore une fois."); +}