/* Copyright (C) 2012-2021 Carl Hetherington This file is part of libdcp. libdcp is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. libdcp is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with libdcp. If not, see . */ #include "cpl.h" #include "dcp.h" #include "interop_subtitle_asset.h" #include "interop_load_font_node.h" #include "reel.h" #include "reel_subtitle_asset.h" #include "subtitle_string.h" #include "subtitle_image.h" #include "test.h" #include #include using std::dynamic_pointer_cast; using std::list; using std::string; using boost::shared_ptr; using boost::dynamic_pointer_cast; /** Load some subtitle content from Interop XML and check that it is read correctly */ BOOST_AUTO_TEST_CASE (read_interop_subtitle_test1) { dcp::InteropSubtitleAsset subs ("test/data/subs1.xml"); BOOST_CHECK_EQUAL (subs.id(), "cab5c268-222b-41d2-88ae-6d6999441b17"); BOOST_CHECK_EQUAL (subs.movie_title(), "Movie Title"); BOOST_CHECK_EQUAL (subs.reel_number(), "1"); BOOST_CHECK_EQUAL (subs.language(), "French"); list > lfn = subs.load_font_nodes (); BOOST_REQUIRE_EQUAL (lfn.size(), 1); shared_ptr interop_lfn = dynamic_pointer_cast (lfn.front ()); BOOST_REQUIRE (interop_lfn); BOOST_CHECK_EQUAL (interop_lfn->id, "theFontId"); BOOST_CHECK_EQUAL (interop_lfn->uri, "arial.ttf"); list > s = subs.subtitles_during (dcp::Time (0, 0, 6, 1, 250), dcp::Time (0, 0, 6, 2, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 1); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFontId"), false, false, false, dcp::Colour (255, 255, 255), 39, 1.0, dcp::Time (0, 0, 5, 198, 250), dcp::Time (0, 0, 7, 115, 250), 0, dcp::HALIGN_CENTER, 0.15, dcp::VALIGN_BOTTOM, dcp::DIRECTION_LTR, "My jacket was Idi Amin's", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 1, 250), dcp::Time (0, 0, 0, 1, 250) )); s = subs.subtitles_during (dcp::Time (0, 0, 7, 190, 250), dcp::Time (0, 0, 7, 191, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFontId"), true, false, false, dcp::Colour (255, 255, 255), 39, 1.0, dcp::Time (0, 0, 7, 177, 250), dcp::Time (0, 0, 11, 31, 250), 0, dcp::HALIGN_CENTER, 0.21, dcp::VALIGN_BOTTOM, dcp::DIRECTION_LTR, "My corset was H.M. The Queen's", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 1, 250), dcp::Time (0, 0, 0, 1, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFontId"), false, false, false, dcp::Colour (255, 255, 255), 39, 1.0, dcp::Time (0, 0, 7, 177, 250), dcp::Time (0, 0, 11, 31, 250), 0, dcp::HALIGN_CENTER, 0.15, dcp::VALIGN_BOTTOM, dcp::DIRECTION_LTR, "My large wonderbra", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 1, 250), dcp::Time (0, 0, 0, 1, 250) )); s = subs.subtitles_during (dcp::Time (0, 0, 11, 95, 250), dcp::Time (0, 0, 11, 96, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 1); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFontId"), false, false, false, dcp::Colour (255, 255, 255), 39, 1.0, dcp::Time (0, 0, 11, 94, 250), dcp::Time (0, 0, 13, 63, 250), 0, dcp::HALIGN_CENTER, 0.15, dcp::VALIGN_BOTTOM, dcp::DIRECTION_LTR, "Once belonged to the Shah", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 1, 250), dcp::Time (0, 0, 0, 1, 250) )); s = subs.subtitles_during (dcp::Time (0, 0, 14, 42, 250), dcp::Time (0, 0, 14, 43, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 1); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFontId"), false, true, true, dcp::Colour (255, 255, 255), 39, 1.0, dcp::Time (0, 0, 13, 104, 250), dcp::Time (0, 0, 15, 177, 250), 0, dcp::HALIGN_CENTER, 0.15, dcp::VALIGN_BOTTOM, dcp::DIRECTION_LTR, "And these are Roy Hattersley's jeans", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 1, 250), dcp::Time (0, 0, 0, 1, 250) )); } /** And similarly for another one */ BOOST_AUTO_TEST_CASE (read_interop_subtitle_test2) { dcp::InteropSubtitleAsset subs ("test/data/subs2.xml"); list > s = subs.subtitles_during (dcp::Time (0, 0, 42, 100, 250), dcp::Time (0, 0, 42, 101, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 0, 41, 62, 250), dcp::Time (0, 0, 43, 52, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "At afternoon tea with John Peel", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 0, 41, 62, 250), dcp::Time (0, 0, 43, 52, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "I enquired if his accent was real", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); s = subs.subtitles_during (dcp::Time (0, 0, 50, 50, 250), dcp::Time (0, 0, 50, 51, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 0, 50, 42, 250), dcp::Time (0, 0, 52, 21, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "He said \"out of the house", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 0, 50, 42, 250), dcp::Time (0, 0, 52, 21, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "I'm incredibly scouse", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); s = subs.subtitles_during (dcp::Time (0, 1, 2, 300, 250), dcp::Time (0, 1, 2, 301, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 2, 208, 250), dcp::Time (0, 1, 4, 10, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "At home it depends how I feel.\"", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 2, 208, 250), dcp::Time (0, 1, 4, 10, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "I spent a long weekend in Brighton", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); s = subs.subtitles_during (dcp::Time (0, 1, 15, 50, 250), dcp::Time (0, 1, 15, 51, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 15, 42, 250), dcp::Time (0, 1, 16, 42, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_RTL, "With the legendary Miss Enid Blyton", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 15, 42, 250), dcp::Time (0, 1, 16, 42, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_TTB, "She said \"you be Noddy", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); s = subs.subtitles_during (dcp::Time (0, 1, 27, 200, 250), dcp::Time (0, 1, 27, 201, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 27, 115, 250), dcp::Time (0, 1, 28, 208, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_BTT, "That curious creature the Sphinx", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 27, 115, 250), dcp::Time (0, 1, 28, 208, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "Is smarter than anyone thinks", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); s = subs.subtitles_during (dcp::Time (0, 1, 42, 300, 250), dcp::Time (0, 1, 42, 301, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), false, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 42, 229, 250), dcp::Time (0, 1, 45, 62, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "It sits there and smirks", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), false, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 42, 229, 250), dcp::Time (0, 1, 45, 62, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "And you don't think it works", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); s = subs.subtitles_during (dcp::Time (0, 1, 45, 200, 250), dcp::Time (0, 1, 45, 201, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), false, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 45, 146, 250), dcp::Time (0, 1, 47, 94, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "Then when you're not looking, it winks.", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), false, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 45, 146, 250), dcp::Time (0, 1, 47, 94, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "When it snows you will find Sister Sledge", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); s = subs.subtitles_during (dcp::Time (0, 1, 47, 249, 250), dcp::Time (0, 1, 47, 250, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), false, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 47, 146, 250), dcp::Time (0, 1, 48, 167, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "Out mooning, at night, on the ledge", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), false, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 1, 47, 146, 250), dcp::Time (0, 1, 48, 167, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "One storey down", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); s = subs.subtitles_during (dcp::Time (0, 2, 6, 210, 250), dcp::Time (0, 2, 6, 211, 250), false); BOOST_REQUIRE_EQUAL (s.size(), 2); BOOST_REQUIRE (dynamic_pointer_cast(s.front())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.front()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 2, 5, 208, 250), dcp::Time (0, 2, 7, 31, 250), 0, dcp::HALIGN_CENTER, 0.89, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "HELLO", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); BOOST_REQUIRE (dynamic_pointer_cast(s.back())); BOOST_CHECK_EQUAL (*dynamic_pointer_cast(s.back()), dcp::SubtitleString ( string ("theFont"), true, false, false, dcp::Colour (255, 255, 255), 42, 1.0, dcp::Time (0, 2, 5, 208, 250), dcp::Time (0, 2, 7, 31, 250), 0, dcp::HALIGN_CENTER, 0.95, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "WORLD", dcp::BORDER, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 250), dcp::Time (0, 0, 0, 0, 250) )); } /** And one with bitmap subtitles */ BOOST_AUTO_TEST_CASE (read_interop_subtitle_test3) { dcp::InteropSubtitleAsset subs ("test/data/subs3.xml"); BOOST_REQUIRE_EQUAL (subs.subtitles().size(), 1); shared_ptr si = dynamic_pointer_cast(subs.subtitles().front()); BOOST_REQUIRE (si); BOOST_CHECK (si->png_image() == dcp::Data("test/data/sub.png")); } /** Write some subtitle content as Interop XML and check that it is right */ BOOST_AUTO_TEST_CASE (write_interop_subtitle_test) { dcp::InteropSubtitleAsset c; c.set_reel_number ("1"); c.set_language ("EN"); c.set_movie_title ("Test"); c.add ( shared_ptr( new dcp::SubtitleString( string ("Frutiger"), false, false, false, dcp::Colour (255, 255, 255), 48, 1.0, dcp::Time (0, 4, 9, 22, 24), dcp::Time (0, 4, 11, 22, 24), 0, dcp::HALIGN_CENTER, 0.8, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "Hello world", dcp::Effect::NONE, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 24), dcp::Time (0, 0, 0, 0, 24) ) ) ); c.add ( shared_ptr( new dcp::SubtitleString( boost::optional (), true, true, true, dcp::Colour (128, 0, 64), 91, 1.0, dcp::Time (5, 41, 0, 21, 24), dcp::Time (6, 12, 15, 21, 24), 0, dcp::HALIGN_CENTER, 0.4, dcp::VALIGN_BOTTOM, dcp::DIRECTION_LTR, "What's going on", dcp::Effect::BORDER, dcp::Colour (1, 2, 3), dcp::Time (1, 2, 3, 4, 24), dcp::Time (5, 6, 7, 8, 24) ) ) ); c._id = "a6c58cff-3e1e-4b38-acec-a42224475ef6"; check_xml ( "" "a6c58cff-3e1e-4b38-acec-a42224475ef6" "Test" "1" "EN" "" "" "Hello world" "" "" "" "" "What's going on" "" "" "", c.xml_as_string (), list() ); } /** Write some subtitle content as Interop XML and check that it is right. * This test includes some horizontal alignment. */ BOOST_AUTO_TEST_CASE (write_interop_subtitle_test2) { dcp::InteropSubtitleAsset c; c.set_reel_number ("1"); c.set_language ("EN"); c.set_movie_title ("Test"); c.add ( shared_ptr( new dcp::SubtitleString( string ("Frutiger"), false, false, false, dcp::Colour (255, 255, 255), 48, 1.0, dcp::Time (0, 4, 9, 22, 24), dcp::Time (0, 4, 11, 22, 24), -0.2, dcp::HALIGN_CENTER, 0.8, dcp::VALIGN_TOP, dcp::DIRECTION_LTR, "Hello world", dcp::Effect::NONE, dcp::Colour (0, 0, 0), dcp::Time (0, 0, 0, 0, 24), dcp::Time (0, 0, 0, 0, 24) ) ) ); c.add ( shared_ptr( new dcp::SubtitleString( boost::optional(), true, true, true, dcp::Colour (128, 0, 64), 91, 1.0, dcp::Time (5, 41, 0, 21, 24), dcp::Time (6, 12, 15, 21, 24), -0.2, dcp::HALIGN_CENTER, 0.4, dcp::VALIGN_BOTTOM, dcp::DIRECTION_LTR, "What's going on", dcp::Effect::BORDER, dcp::Colour (1, 2, 3), dcp::Time (1, 2, 3, 4, 24), dcp::Time (5, 6, 7, 8, 24) ) ) ); c._id = "a6c58cff-3e1e-4b38-acec-a42224475ef6"; check_xml ( "" "a6c58cff-3e1e-4b38-acec-a42224475ef6" "Test" "1" "EN" "" "" "Hello world" "" "" "" "" "What's going on" "" "" "", c.xml_as_string (), list() ); } /* Write some subtitle content as Interop XML using bitmaps and check that it is right */ BOOST_AUTO_TEST_CASE (write_interop_subtitle_test3) { shared_ptr c = shared_ptr(new dcp::InteropSubtitleAsset()); c->set_reel_number ("1"); c->set_language ("EN"); c->set_movie_title ("Test"); c->add ( shared_ptr( new dcp::SubtitleImage( dcp::Data ("test/data/sub.png"), dcp::Time (0, 4, 9, 22, 24), dcp::Time (0, 4, 11, 22, 24), 0, dcp::HALIGN_CENTER, 0.8, dcp::VALIGN_TOP, dcp::Time (0, 0, 0, 0, 24), dcp::Time (0, 0, 0, 0, 24) ) ) ); c->_id = "a6c58cff-3e1e-4b38-acec-a42224475ef6"; boost::filesystem::remove_all ("build/test/write_interop_subtitle_test3"); boost::filesystem::create_directories ("build/test/write_interop_subtitle_test3"); c->write ("build/test/write_interop_subtitle_test3/subs.xml"); shared_ptr reel(new dcp::Reel()); reel->add(shared_ptr(new dcp::ReelSubtitleAsset(c, dcp::Fraction(24, 1), 6046, 0))); dcp::XMLMetadata meta; meta.issue_date = "2018-09-02T04:45:18+00:00"; meta.issuer = "libdcp"; meta.creator = "libdcp"; meta.annotation_text = "Created by libdcp"; shared_ptr cpl(new dcp::CPL("My film", dcp::FEATURE)); cpl->add (reel); cpl->set_metadata (meta); cpl->set_content_version_label_text ("foo"); dcp::DCP dcp ("build/test/write_interop_subtitle_test3"); dcp.add (cpl); dcp.write_xml (dcp::INTEROP, meta); check_xml ( dcp::file_to_string("test/ref/write_interop_subtitle_test3/subs.xml"), dcp::file_to_string("build/test/write_interop_subtitle_test3/subs.xml"), list() ); check_file ("build/test/write_interop_subtitle_test3/eff79796-4889-4c55-b422-6049d069f6ce.png", "test/data/sub.png"); check_xml ( dcp::file_to_string("test/ref/write_interop_subtitle_test3/ASSETMAP"), dcp::file_to_string("build/test/write_interop_subtitle_test3/ASSETMAP"), list() ); check_xml ( dcp::file_to_string("test/ref/write_interop_subtitle_test3/pkl.xml"), dcp::file_to_string("build/test/write_interop_subtitle_test3/pkl_b89b2bba-9841-4c74-8748-7f6f23217d7c.xml"), list() ); }