X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fsubtitle_language_test.cc;h=6ae0647e9ebfd5328f922beda71efc6ea1527046;hb=HEAD;hp=e198b78f93c9cd350cb8923dc4c8f9c8f1f8e888;hpb=689fa55d1529ad88449ca464e9107c4dcc54d1cb;p=dcpomatic.git diff --git a/test/subtitle_language_test.cc b/test/subtitle_language_test.cc index e198b78f9..6ae0647e9 100644 --- a/test/subtitle_language_test.cc +++ b/test/subtitle_language_test.cc @@ -36,17 +36,17 @@ using std::string; using std::vector; -using std::shared_ptr; BOOST_AUTO_TEST_CASE (subtitle_language_interop_test) { string const name = "subtitle_language_interop_test"; - auto fr = content_factory("test/data/frames.srt").front(); - auto film = new_test_film2 (name, { fr }); + auto fr = content_factory("test/data/frames.srt"); + auto film = new_test_film2 (name, fr); - fr->only_text()->set_language (dcp::LanguageTag("fr-FR")); + fr[0]->only_text()->set_language(dcp::LanguageTag("fr")); film->set_interop (true); + film->set_audio_channels(6); make_and_verify_dcp ( film, @@ -54,19 +54,23 @@ BOOST_AUTO_TEST_CASE (subtitle_language_interop_test) dcp::VerificationNote::Code::INVALID_STANDARD, dcp::VerificationNote::Code::INVALID_SUBTITLE_SPACING, dcp::VerificationNote::Code::INVALID_SUBTITLE_DURATION - }); + }, + false, + /* clairmeta raises errors about subtitle spacing/duration */ + false + ); - check_dcp (String::compose("test/data/%1", name), String::compose("build/test/%1/%2", name, film->dcp_name())); + check_dcp(String::compose("test/data/%1", name), String::compose("build/test/%1/%2", name, film->dcp_name())); } BOOST_AUTO_TEST_CASE (subtitle_language_smpte_test) { string const name = "subtitle_language_smpte_test"; - auto fr = content_factory("test/data/frames.srt").front(); - auto film = new_test_film2 (name, { fr }); + auto fr = content_factory("test/data/frames.srt"); + auto film = new_test_film2 (name, fr); - fr->only_text()->set_language (dcp::LanguageTag("fr-FR")); + fr[0]->only_text()->set_language(dcp::LanguageTag("fr")); film->set_interop (false); make_and_verify_dcp ( @@ -79,6 +83,39 @@ BOOST_AUTO_TEST_CASE (subtitle_language_smpte_test) dcp::VerificationNote::Code::MISSING_CPL_METADATA }); - check_dcp (String::compose("test/data/%1", name), String::compose("build/test/%1/%2", name, film->dcp_name())); + /* This test is concerned with the subtitles, so we'll ignore any + * differences in sound between the DCP and the reference to avoid test + * failures for unrelated reasons. + */ + check_dcp(String::compose("test/data/%1", name), String::compose("build/test/%1/%2", name, film->dcp_name()), true); +} + + +BOOST_AUTO_TEST_CASE(subtitle_language_in_cpl_test) +{ + auto subs = content_factory("test/data/frames.srt")[0]; + auto video1 = content_factory("test/data/flat_red.png")[0]; + auto video2 = content_factory("test/data/flat_red.png")[0]; + auto film = new_test_film2(boost::unit_test::framework::current_test_unit().full_name(), { subs, video1, video2 }); + video2->set_position(film, dcpomatic::DCPTime::from_seconds(5)); + film->set_reel_type(ReelType::BY_VIDEO_CONTENT); + subs->only_text()->set_language(dcp::LanguageTag("fr")); + + make_and_verify_dcp( + film, + { + dcp::VerificationNote::Code::INVALID_SUBTITLE_FIRST_TEXT_TIME, + dcp::VerificationNote::Code::INVALID_SUBTITLE_DURATION, + dcp::VerificationNote::Code::INVALID_SUBTITLE_SPACING + }); + + cxml::Document cpl("CompositionPlaylist"); + cpl.read_file(find_file(film->dir(film->dcp_name()), "cpl_")); + + for (auto reel: cpl.node_child("ReelList")->node_children("Reel")) { + auto subtitle = reel->node_child("AssetList")->node_child("MainSubtitle"); + BOOST_REQUIRE(subtitle); + BOOST_CHECK(subtitle->optional_node_child("Language")); + } }