X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fsubtitle_font_id_test.cc;h=b55562c227898bd338f09d52e140453eabfb3ea0;hb=5bc0f9a0e433e344e269411d20a106c65841b423;hp=41bc3a9230b3d58d35c5bdf83c8e3c014ebee67a;hpb=8b9888ed8247109dc3c09492302e865fa4731460;p=dcpomatic.git diff --git a/test/subtitle_font_id_test.cc b/test/subtitle_font_id_test.cc index 41bc3a923..b55562c22 100644 --- a/test/subtitle_font_id_test.cc +++ b/test/subtitle_font_id_test.cc @@ -24,11 +24,17 @@ #include "lib/film.h" #include "lib/font.h" #include "lib/text_content.h" +#include +#include +#include +#include +#include #include "test.h" #include using std::make_shared; +using std::shared_ptr; BOOST_AUTO_TEST_CASE(full_dcp_subtitle_font_id_test) @@ -51,8 +57,8 @@ BOOST_AUTO_TEST_CASE(full_dcp_subtitle_font_id_test) BOOST_AUTO_TEST_CASE(dcp_subtitle_font_id_test) { - auto subs = content_factory(TestPaths::private_data() / "JourneyToJah_TLR-1_F_EN-DE-FR_CH_51_2K_LOK_20140225_DGL_SMPTE_OV" / "8b48f6ae-c74b-4b80-b994-a8236bbbad74_sub.mxf").front(); - auto film = new_test_film2("dcp_subtitle_font_id_test", { subs }); + auto subs = content_factory(TestPaths::private_data() / "JourneyToJah_TLR-1_F_EN-DE-FR_CH_51_2K_LOK_20140225_DGL_SMPTE_OV" / "8b48f6ae-c74b-4b80-b994-a8236bbbad74_sub.mxf"); + auto film = new_test_film2("dcp_subtitle_font_id_test", subs); auto content = film->content(); BOOST_REQUIRE_EQUAL(content.size(), 1U); @@ -90,3 +96,94 @@ BOOST_AUTO_TEST_CASE(make_dcp_with_subs_from_smpte_dcp) make_and_verify_dcp(film); } + +BOOST_AUTO_TEST_CASE(make_dcp_with_subs_from_mkv) +{ + auto subs = content_factory(TestPaths::private_data() / "clapperboard_with_subs.mkv"); + auto film = new_test_film2("make_dcp_with_subs_from_mkv", subs); + subs[0]->text.front()->set_use(true); + subs[0]->text.front()->set_language(dcp::LanguageTag("en-US")); + make_and_verify_dcp(film, { dcp::VerificationNote::Code::INVALID_PICTURE_FRAME_RATE_FOR_2K }); +} + + +BOOST_AUTO_TEST_CASE(make_dcp_with_subs_without_font_tag) +{ + auto subs = content_factory("test/data/no_font.xml"); + auto film = new_test_film2("make_dcp_with_subs_without_font_tag", { subs }); + subs[0]->text.front()->set_use(true); + make_and_verify_dcp( + film, + { + dcp::VerificationNote::Code::MISSING_SUBTITLE_LANGUAGE, + dcp::VerificationNote::Code::INVALID_SUBTITLE_FIRST_TEXT_TIME, + dcp::VerificationNote::Code::MISSING_CPL_METADATA + }); + + auto check_file = subtitle_file(film); + dcp::SMPTESubtitleAsset check_asset(check_file); + BOOST_CHECK_EQUAL(check_asset.load_font_nodes().size(), 1U); + auto check_font_data = check_asset.font_data(); + BOOST_CHECK_EQUAL(check_font_data.size(), 1U); + BOOST_CHECK(check_font_data.begin()->second == dcp::ArrayData(default_font_file())); +} + + +BOOST_AUTO_TEST_CASE(make_dcp_with_subs_in_dcp_without_font_tag) +{ + /* Make a DCP with some subs in */ + auto source_subs = content_factory("test/data/short.srt"); + auto source = new_test_film2("make_dcp_with_subs_in_dcp_without_font_tag_source", { source_subs }); + source->set_interop(true); + make_and_verify_dcp( + source, + { + dcp::VerificationNote::Code::MISSING_SUBTITLE_LANGUAGE, + dcp::VerificationNote::Code::INVALID_SUBTITLE_FIRST_TEXT_TIME, + dcp::VerificationNote::Code::MISSING_CPL_METADATA, + dcp::VerificationNote::Code::INVALID_STANDARD + }); + + /* Find the ID of the subs */ + dcp::DCP source_dcp(source->dir(source->dcp_name())); + source_dcp.read(); + BOOST_REQUIRE(!source_dcp.cpls().empty()); + BOOST_REQUIRE(!source_dcp.cpls()[0]->reels().empty()); + BOOST_REQUIRE(source_dcp.cpls()[0]->reels()[0]->main_subtitle()); + auto const id = source_dcp.cpls()[0]->reels()[0]->main_subtitle()->asset()->id(); + + /* Graft in some bad subs with no tag */ + auto source_subtitle_file = subtitle_file(source); +#if BOOST_VERSION >= 107400 + boost::filesystem::copy_file("test/data/no_font.xml", source_subtitle_file, boost::filesystem::copy_options::overwrite_existing); +#else + boost::filesystem::copy_file("test/data/no_font.xml", source_subtitle_file, boost::filesystem::copy_option::overwrite_existing); +#endif + + /* Fix the tag */ + { + Editor editor(source_subtitle_file); + editor.replace("4dd8ee05-5986-4c67-a6f8-bbeac62e21db", id); + } + + /* Now make a project which imports that DCP and makes another DCP from it */ + auto dcp_content = make_shared(source->dir(source->dcp_name())); + auto film = new_test_film2("make_dcp_with_subs_without_font_tag", { dcp_content }); + BOOST_REQUIRE(!dcp_content->text.empty()); + dcp_content->text.front()->set_use(true); + make_and_verify_dcp( + film, + { + dcp::VerificationNote::Code::MISSING_SUBTITLE_LANGUAGE, + dcp::VerificationNote::Code::INVALID_SUBTITLE_FIRST_TEXT_TIME, + dcp::VerificationNote::Code::MISSING_CPL_METADATA + }); + + auto check_file = subtitle_file(film); + dcp::SMPTESubtitleAsset check_asset(check_file); + BOOST_CHECK_EQUAL(check_asset.load_font_nodes().size(), 1U); + auto check_font_data = check_asset.font_data(); + BOOST_CHECK_EQUAL(check_font_data.size(), 1U); + BOOST_CHECK(check_font_data.begin()->second == dcp::ArrayData(default_font_file())); +} +