2 Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net>
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 #include "interop_subtitle_asset.h"
21 #include "interop_load_font_node.h"
22 #include "subtitle_string.h"
23 #include <boost/test/unit_test.hpp>
27 using boost::shared_ptr;
28 using boost::dynamic_pointer_cast;
30 /** Load some subtitle content from Interop XML and check that it is read correctly */
31 BOOST_AUTO_TEST_CASE (read_interop_subtitle_test1)
33 dcp::InteropSubtitleAsset subs ("test/data/subs1.xml");
35 BOOST_CHECK_EQUAL (subs.id(), "cab5c268-222b-41d2-88ae-6d6999441b17");
36 BOOST_CHECK_EQUAL (subs.movie_title(), "Movie Title");
37 BOOST_CHECK_EQUAL (subs.reel_number(), "1");
38 BOOST_CHECK_EQUAL (subs.language(), "French");
40 list<shared_ptr<dcp::LoadFontNode> > lfn = subs.load_font_nodes ();
41 BOOST_REQUIRE_EQUAL (lfn.size(), 1);
42 shared_ptr<dcp::InteropLoadFontNode> interop_lfn = dynamic_pointer_cast<dcp::InteropLoadFontNode> (lfn.front ());
43 BOOST_REQUIRE (interop_lfn);
44 BOOST_CHECK_EQUAL (interop_lfn->id, "theFontId");
45 BOOST_CHECK_EQUAL (interop_lfn->uri, "arial.ttf");
47 list<dcp::SubtitleString> s = subs.subtitles_during (dcp::Time (0, 0, 6, 1, 250), dcp::Time (0, 0, 6, 2, 250), false);
48 BOOST_REQUIRE_EQUAL (s.size(), 1);
49 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
53 dcp::Colour (255, 255, 255),
56 dcp::Time (0, 0, 5, 198, 250),
57 dcp::Time (0, 0, 7, 115, 250),
62 "My jacket was Idi Amin's",
64 dcp::Colour (0, 0, 0),
65 dcp::Time (0, 0, 0, 1, 250),
66 dcp::Time (0, 0, 0, 1, 250)
69 s = subs.subtitles_during (dcp::Time (0, 0, 7, 190, 250), dcp::Time (0, 0, 7, 191, 250), false);
70 BOOST_REQUIRE_EQUAL (s.size(), 2);
71 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
75 dcp::Colour (255, 255, 255),
78 dcp::Time (0, 0, 7, 177, 250),
79 dcp::Time (0, 0, 11, 31, 250),
84 "My corset was H.M. The Queen's",
86 dcp::Colour (0, 0, 0),
87 dcp::Time (0, 0, 0, 1, 250),
88 dcp::Time (0, 0, 0, 1, 250)
90 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
94 dcp::Colour (255, 255, 255),
97 dcp::Time (0, 0, 7, 177, 250),
98 dcp::Time (0, 0, 11, 31, 250),
103 "My large wonderbra",
105 dcp::Colour (0, 0, 0),
106 dcp::Time (0, 0, 0, 1, 250),
107 dcp::Time (0, 0, 0, 1, 250)
110 s = subs.subtitles_during (dcp::Time (0, 0, 11, 95, 250), dcp::Time (0, 0, 11, 96, 250), false);
111 BOOST_REQUIRE_EQUAL (s.size(), 1);
112 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
113 string ("theFontId"),
116 dcp::Colour (255, 255, 255),
119 dcp::Time (0, 0, 11, 94, 250),
120 dcp::Time (0, 0, 13, 63, 250),
125 "Once belonged to the Shah",
127 dcp::Colour (0, 0, 0),
128 dcp::Time (0, 0, 0, 1, 250),
129 dcp::Time (0, 0, 0, 1, 250)
132 s = subs.subtitles_during (dcp::Time (0, 0, 14, 42, 250), dcp::Time (0, 0, 14, 43, 250), false);
133 BOOST_REQUIRE_EQUAL (s.size(), 1);
134 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
135 string ("theFontId"),
138 dcp::Colour (255, 255, 255),
141 dcp::Time (0, 0, 13, 104, 250),
142 dcp::Time (0, 0, 15, 177, 250),
147 "And these are Roy Hattersley's jeans",
149 dcp::Colour (0, 0, 0),
150 dcp::Time (0, 0, 0, 1, 250),
151 dcp::Time (0, 0, 0, 1, 250)
155 /** And similarly for another one */
156 BOOST_AUTO_TEST_CASE (read_interop_subtitle_test2)
158 dcp::InteropSubtitleAsset subs ("test/data/subs2.xml");
160 list<dcp::SubtitleString> s = subs.subtitles_during (dcp::Time (0, 0, 42, 100, 250), dcp::Time (0, 0, 42, 101, 250), false);
161 BOOST_REQUIRE_EQUAL (s.size(), 2);
162 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
166 dcp::Colour (255, 255, 255),
169 dcp::Time (0, 0, 41, 62, 250),
170 dcp::Time (0, 0, 43, 52, 250),
175 "At afternoon tea with John Peel",
177 dcp::Colour (0, 0, 0),
178 dcp::Time (0, 0, 0, 0, 250),
179 dcp::Time (0, 0, 0, 0, 250)
181 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
185 dcp::Colour (255, 255, 255),
188 dcp::Time (0, 0, 41, 62, 250),
189 dcp::Time (0, 0, 43, 52, 250),
194 "I enquired if his accent was real",
196 dcp::Colour (0, 0, 0),
197 dcp::Time (0, 0, 0, 0, 250),
198 dcp::Time (0, 0, 0, 0, 250)
201 s = subs.subtitles_during (dcp::Time (0, 0, 50, 50, 250), dcp::Time (0, 0, 50, 51, 250), false);
202 BOOST_REQUIRE_EQUAL (s.size(), 2);
203 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
207 dcp::Colour (255, 255, 255),
210 dcp::Time (0, 0, 50, 42, 250),
211 dcp::Time (0, 0, 52, 21, 250),
216 "He said \"out of the house",
218 dcp::Colour (0, 0, 0),
219 dcp::Time (0, 0, 0, 0, 250),
220 dcp::Time (0, 0, 0, 0, 250)
222 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
226 dcp::Colour (255, 255, 255),
229 dcp::Time (0, 0, 50, 42, 250),
230 dcp::Time (0, 0, 52, 21, 250),
235 "I'm incredibly scouse",
237 dcp::Colour (0, 0, 0),
238 dcp::Time (0, 0, 0, 0, 250),
239 dcp::Time (0, 0, 0, 0, 250)
242 s = subs.subtitles_during (dcp::Time (0, 1, 2, 300, 250), dcp::Time (0, 1, 2, 301, 250), false);
243 BOOST_REQUIRE_EQUAL (s.size(), 2);
244 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
248 dcp::Colour (255, 255, 255),
251 dcp::Time (0, 1, 2, 208, 250),
252 dcp::Time (0, 1, 4, 10, 250),
257 "At home it depends how I feel.\"",
259 dcp::Colour (0, 0, 0),
260 dcp::Time (0, 0, 0, 0, 250),
261 dcp::Time (0, 0, 0, 0, 250)
263 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
267 dcp::Colour (255, 255, 255),
270 dcp::Time (0, 1, 2, 208, 250),
271 dcp::Time (0, 1, 4, 10, 250),
276 "I spent a long weekend in Brighton",
278 dcp::Colour (0, 0, 0),
279 dcp::Time (0, 0, 0, 0, 250),
280 dcp::Time (0, 0, 0, 0, 250)
283 s = subs.subtitles_during (dcp::Time (0, 1, 15, 50, 250), dcp::Time (0, 1, 15, 51, 250), false);
284 BOOST_REQUIRE_EQUAL (s.size(), 2);
285 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
289 dcp::Colour (255, 255, 255),
292 dcp::Time (0, 1, 15, 42, 250),
293 dcp::Time (0, 1, 16, 42, 250),
298 "With the legendary Miss Enid Blyton",
300 dcp::Colour (0, 0, 0),
301 dcp::Time (0, 0, 0, 0, 250),
302 dcp::Time (0, 0, 0, 0, 250)
304 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
308 dcp::Colour (255, 255, 255),
311 dcp::Time (0, 1, 15, 42, 250),
312 dcp::Time (0, 1, 16, 42, 250),
317 "She said \"you be Noddy",
319 dcp::Colour (0, 0, 0),
320 dcp::Time (0, 0, 0, 0, 250),
321 dcp::Time (0, 0, 0, 0, 250)
324 s = subs.subtitles_during (dcp::Time (0, 1, 27, 200, 250), dcp::Time (0, 1, 27, 201, 250), false);
325 BOOST_REQUIRE_EQUAL (s.size(), 2);
326 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
330 dcp::Colour (255, 255, 255),
333 dcp::Time (0, 1, 27, 115, 250),
334 dcp::Time (0, 1, 28, 208, 250),
339 "That curious creature the Sphinx",
341 dcp::Colour (0, 0, 0),
342 dcp::Time (0, 0, 0, 0, 250),
343 dcp::Time (0, 0, 0, 0, 250)
345 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
349 dcp::Colour (255, 255, 255),
352 dcp::Time (0, 1, 27, 115, 250),
353 dcp::Time (0, 1, 28, 208, 250),
358 "Is smarter than anyone thinks",
360 dcp::Colour (0, 0, 0),
361 dcp::Time (0, 0, 0, 0, 250),
362 dcp::Time (0, 0, 0, 0, 250)
365 s = subs.subtitles_during (dcp::Time (0, 1, 42, 300, 250), dcp::Time (0, 1, 42, 301, 250), false);
366 BOOST_REQUIRE_EQUAL (s.size(), 2);
367 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
371 dcp::Colour (255, 255, 255),
374 dcp::Time (0, 1, 42, 229, 250),
375 dcp::Time (0, 1, 45, 62, 250),
380 "It sits there and smirks",
382 dcp::Colour (0, 0, 0),
383 dcp::Time (0, 0, 0, 0, 250),
384 dcp::Time (0, 0, 0, 0, 250)
386 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
390 dcp::Colour (255, 255, 255),
393 dcp::Time (0, 1, 42, 229, 250),
394 dcp::Time (0, 1, 45, 62, 250),
399 "And you don't think it works",
401 dcp::Colour (0, 0, 0),
402 dcp::Time (0, 0, 0, 0, 250),
403 dcp::Time (0, 0, 0, 0, 250)
406 s = subs.subtitles_during (dcp::Time (0, 1, 45, 200, 250), dcp::Time (0, 1, 45, 201, 250), false);
407 BOOST_REQUIRE_EQUAL (s.size(), 2);
408 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
412 dcp::Colour (255, 255, 255),
415 dcp::Time (0, 1, 45, 146, 250),
416 dcp::Time (0, 1, 47, 94, 250),
421 "Then when you're not looking, it winks.",
423 dcp::Colour (0, 0, 0),
424 dcp::Time (0, 0, 0, 0, 250),
425 dcp::Time (0, 0, 0, 0, 250)
427 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
431 dcp::Colour (255, 255, 255),
434 dcp::Time (0, 1, 45, 146, 250),
435 dcp::Time (0, 1, 47, 94, 250),
440 "When it snows you will find Sister Sledge",
442 dcp::Colour (0, 0, 0),
443 dcp::Time (0, 0, 0, 0, 250),
444 dcp::Time (0, 0, 0, 0, 250)
447 s = subs.subtitles_during (dcp::Time (0, 1, 47, 249, 250), dcp::Time (0, 1, 47, 250, 250), false);
448 BOOST_REQUIRE_EQUAL (s.size(), 2);
449 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
453 dcp::Colour (255, 255, 255),
456 dcp::Time (0, 1, 47, 146, 250),
457 dcp::Time (0, 1, 48, 167, 250),
462 "Out mooning, at night, on the ledge",
464 dcp::Colour (0, 0, 0),
465 dcp::Time (0, 0, 0, 0, 250),
466 dcp::Time (0, 0, 0, 0, 250)
468 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
472 dcp::Colour (255, 255, 255),
475 dcp::Time (0, 1, 47, 146, 250),
476 dcp::Time (0, 1, 48, 167, 250),
483 dcp::Colour (0, 0, 0),
484 dcp::Time (0, 0, 0, 0, 250),
485 dcp::Time (0, 0, 0, 0, 250)
488 s = subs.subtitles_during (dcp::Time (0, 2, 6, 210, 250), dcp::Time (0, 2, 6, 211, 250), false);
489 BOOST_REQUIRE_EQUAL (s.size(), 2);
490 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
494 dcp::Colour (255, 255, 255),
497 dcp::Time (0, 2, 5, 208, 250),
498 dcp::Time (0, 2, 7, 31, 250),
505 dcp::Colour (0, 0, 0),
506 dcp::Time (0, 0, 0, 0, 250),
507 dcp::Time (0, 0, 0, 0, 250)
509 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
513 dcp::Colour (255, 255, 255),
516 dcp::Time (0, 2, 5, 208, 250),
517 dcp::Time (0, 2, 7, 31, 250),
524 dcp::Colour (0, 0, 0),
525 dcp::Time (0, 0, 0, 0, 250),
526 dcp::Time (0, 0, 0, 0, 250)