diff options
| author | Carl Hetherington <cth@carlh.net> | 2015-07-06 00:28:42 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2015-07-06 00:28:42 +0100 |
| commit | 3bb6308d1b17aa643021bddc82e954029076f780 (patch) | |
| tree | 1edfbb47d93aa76e9dedea8e63be9f76797fdccc /test | |
| parent | d3d26828db1cc559b427e7ba1f5572622696d2d8 (diff) | |
Implement missing support for DCP subs inside DCP content (#631).
Diffstat (limited to 'test')
| -rw-r--r-- | test/dcp_subtitle_test.cc | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/test/dcp_subtitle_test.cc b/test/dcp_subtitle_test.cc index e8a5a4c04..9007ad611 100644 --- a/test/dcp_subtitle_test.cc +++ b/test/dcp_subtitle_test.cc @@ -24,11 +24,14 @@ #include <boost/test/unit_test.hpp> #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" using std::cout; +using std::list; using boost::shared_ptr; /** Test pass-through of a very simple DCP subtitle file */ @@ -51,3 +54,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> 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<DCPContent> 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<DCPDecoder> decoder (new DCPDecoder (content)); + + list<ContentTimePeriod> 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<ContentTextSubtitle> 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."); +} |
