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 (
52 dcp::Colour (255, 255, 255),
55 dcp::Time (0, 0, 5, 198, 250),
56 dcp::Time (0, 0, 7, 115, 250),
61 "My jacket was Idi Amin's",
63 dcp::Colour (0, 0, 0),
64 dcp::Time (0, 0, 0, 1, 250),
65 dcp::Time (0, 0, 0, 1, 250)
68 s = subs.subtitles_during (dcp::Time (0, 0, 7, 190, 250), dcp::Time (0, 0, 7, 191, 250), false);
69 BOOST_REQUIRE_EQUAL (s.size(), 2);
70 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
73 dcp::Colour (255, 255, 255),
76 dcp::Time (0, 0, 7, 177, 250),
77 dcp::Time (0, 0, 11, 31, 250),
82 "My corset was H.M. The Queen's",
84 dcp::Colour (0, 0, 0),
85 dcp::Time (0, 0, 0, 1, 250),
86 dcp::Time (0, 0, 0, 1, 250)
88 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
91 dcp::Colour (255, 255, 255),
94 dcp::Time (0, 0, 7, 177, 250),
95 dcp::Time (0, 0, 11, 31, 250),
100 "My large wonderbra",
102 dcp::Colour (0, 0, 0),
103 dcp::Time (0, 0, 0, 1, 250),
104 dcp::Time (0, 0, 0, 1, 250)
107 s = subs.subtitles_during (dcp::Time (0, 0, 11, 95, 250), dcp::Time (0, 0, 11, 96, 250), false);
108 BOOST_REQUIRE_EQUAL (s.size(), 1);
109 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
110 string ("theFontId"),
112 dcp::Colour (255, 255, 255),
115 dcp::Time (0, 0, 11, 94, 250),
116 dcp::Time (0, 0, 13, 63, 250),
121 "Once belonged to the Shah",
123 dcp::Colour (0, 0, 0),
124 dcp::Time (0, 0, 0, 1, 250),
125 dcp::Time (0, 0, 0, 1, 250)
128 s = subs.subtitles_during (dcp::Time (0, 0, 14, 42, 250), dcp::Time (0, 0, 14, 43, 250), false);
129 BOOST_REQUIRE_EQUAL (s.size(), 1);
130 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
131 string ("theFontId"),
133 dcp::Colour (255, 255, 255),
136 dcp::Time (0, 0, 13, 104, 250),
137 dcp::Time (0, 0, 15, 177, 250),
142 "And these are Roy Hattersley's jeans",
144 dcp::Colour (0, 0, 0),
145 dcp::Time (0, 0, 0, 1, 250),
146 dcp::Time (0, 0, 0, 1, 250)
150 /** And similarly for another one */
151 BOOST_AUTO_TEST_CASE (read_interop_subtitle_test2)
153 dcp::InteropSubtitleAsset subs ("test/data/subs2.xml");
155 list<dcp::SubtitleString> s = subs.subtitles_during (dcp::Time (0, 0, 42, 100, 250), dcp::Time (0, 0, 42, 101, 250), false);
156 BOOST_REQUIRE_EQUAL (s.size(), 2);
157 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
160 dcp::Colour (255, 255, 255),
163 dcp::Time (0, 0, 41, 62, 250),
164 dcp::Time (0, 0, 43, 52, 250),
169 "At afternoon tea with John Peel",
171 dcp::Colour (0, 0, 0),
172 dcp::Time (0, 0, 0, 0, 250),
173 dcp::Time (0, 0, 0, 0, 250)
175 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
178 dcp::Colour (255, 255, 255),
181 dcp::Time (0, 0, 41, 62, 250),
182 dcp::Time (0, 0, 43, 52, 250),
187 "I enquired if his accent was real",
189 dcp::Colour (0, 0, 0),
190 dcp::Time (0, 0, 0, 0, 250),
191 dcp::Time (0, 0, 0, 0, 250)
194 s = subs.subtitles_during (dcp::Time (0, 0, 50, 50, 250), dcp::Time (0, 0, 50, 51, 250), false);
195 BOOST_REQUIRE_EQUAL (s.size(), 2);
196 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
199 dcp::Colour (255, 255, 255),
202 dcp::Time (0, 0, 50, 42, 250),
203 dcp::Time (0, 0, 52, 21, 250),
208 "He said \"out of the house",
210 dcp::Colour (0, 0, 0),
211 dcp::Time (0, 0, 0, 0, 250),
212 dcp::Time (0, 0, 0, 0, 250)
214 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
217 dcp::Colour (255, 255, 255),
220 dcp::Time (0, 0, 50, 42, 250),
221 dcp::Time (0, 0, 52, 21, 250),
226 "I'm incredibly scouse",
228 dcp::Colour (0, 0, 0),
229 dcp::Time (0, 0, 0, 0, 250),
230 dcp::Time (0, 0, 0, 0, 250)
233 s = subs.subtitles_during (dcp::Time (0, 1, 2, 300, 250), dcp::Time (0, 1, 2, 301, 250), false);
234 BOOST_REQUIRE_EQUAL (s.size(), 2);
235 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
238 dcp::Colour (255, 255, 255),
241 dcp::Time (0, 1, 2, 208, 250),
242 dcp::Time (0, 1, 4, 10, 250),
247 "At home it depends how I feel.\"",
249 dcp::Colour (0, 0, 0),
250 dcp::Time (0, 0, 0, 0, 250),
251 dcp::Time (0, 0, 0, 0, 250)
253 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
256 dcp::Colour (255, 255, 255),
259 dcp::Time (0, 1, 2, 208, 250),
260 dcp::Time (0, 1, 4, 10, 250),
265 "I spent a long weekend in Brighton",
267 dcp::Colour (0, 0, 0),
268 dcp::Time (0, 0, 0, 0, 250),
269 dcp::Time (0, 0, 0, 0, 250)
272 s = subs.subtitles_during (dcp::Time (0, 1, 15, 50, 250), dcp::Time (0, 1, 15, 51, 250), false);
273 BOOST_REQUIRE_EQUAL (s.size(), 2);
274 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
277 dcp::Colour (255, 255, 255),
280 dcp::Time (0, 1, 15, 42, 250),
281 dcp::Time (0, 1, 16, 42, 250),
286 "With the legendary Miss Enid Blyton",
288 dcp::Colour (0, 0, 0),
289 dcp::Time (0, 0, 0, 0, 250),
290 dcp::Time (0, 0, 0, 0, 250)
292 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
295 dcp::Colour (255, 255, 255),
298 dcp::Time (0, 1, 15, 42, 250),
299 dcp::Time (0, 1, 16, 42, 250),
304 "She said \"you be Noddy",
306 dcp::Colour (0, 0, 0),
307 dcp::Time (0, 0, 0, 0, 250),
308 dcp::Time (0, 0, 0, 0, 250)
311 s = subs.subtitles_during (dcp::Time (0, 1, 27, 200, 250), dcp::Time (0, 1, 27, 201, 250), false);
312 BOOST_REQUIRE_EQUAL (s.size(), 2);
313 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
316 dcp::Colour (255, 255, 255),
319 dcp::Time (0, 1, 27, 115, 250),
320 dcp::Time (0, 1, 28, 208, 250),
325 "That curious creature the Sphinx",
327 dcp::Colour (0, 0, 0),
328 dcp::Time (0, 0, 0, 0, 250),
329 dcp::Time (0, 0, 0, 0, 250)
331 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
334 dcp::Colour (255, 255, 255),
337 dcp::Time (0, 1, 27, 115, 250),
338 dcp::Time (0, 1, 28, 208, 250),
343 "Is smarter than anyone thinks",
345 dcp::Colour (0, 0, 0),
346 dcp::Time (0, 0, 0, 0, 250),
347 dcp::Time (0, 0, 0, 0, 250)
350 s = subs.subtitles_during (dcp::Time (0, 1, 42, 300, 250), dcp::Time (0, 1, 42, 301, 250), false);
351 BOOST_REQUIRE_EQUAL (s.size(), 2);
352 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
355 dcp::Colour (255, 255, 255),
358 dcp::Time (0, 1, 42, 229, 250),
359 dcp::Time (0, 1, 45, 62, 250),
364 "It sits there and smirks",
366 dcp::Colour (0, 0, 0),
367 dcp::Time (0, 0, 0, 0, 250),
368 dcp::Time (0, 0, 0, 0, 250)
370 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
373 dcp::Colour (255, 255, 255),
376 dcp::Time (0, 1, 42, 229, 250),
377 dcp::Time (0, 1, 45, 62, 250),
382 "And you don't think it works",
384 dcp::Colour (0, 0, 0),
385 dcp::Time (0, 0, 0, 0, 250),
386 dcp::Time (0, 0, 0, 0, 250)
389 s = subs.subtitles_during (dcp::Time (0, 1, 45, 200, 250), dcp::Time (0, 1, 45, 201, 250), false);
390 BOOST_REQUIRE_EQUAL (s.size(), 2);
391 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
394 dcp::Colour (255, 255, 255),
397 dcp::Time (0, 1, 45, 146, 250),
398 dcp::Time (0, 1, 47, 94, 250),
403 "Then when you're not looking, it winks.",
405 dcp::Colour (0, 0, 0),
406 dcp::Time (0, 0, 0, 0, 250),
407 dcp::Time (0, 0, 0, 0, 250)
409 BOOST_CHECK_EQUAL (s.back(), 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 "When it snows you will find Sister Sledge",
423 dcp::Colour (0, 0, 0),
424 dcp::Time (0, 0, 0, 0, 250),
425 dcp::Time (0, 0, 0, 0, 250)
428 s = subs.subtitles_during (dcp::Time (0, 1, 47, 249, 250), dcp::Time (0, 1, 47, 250, 250), false);
429 BOOST_REQUIRE_EQUAL (s.size(), 2);
430 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
433 dcp::Colour (255, 255, 255),
436 dcp::Time (0, 1, 47, 146, 250),
437 dcp::Time (0, 1, 48, 167, 250),
442 "Out mooning, at night, on the ledge",
444 dcp::Colour (0, 0, 0),
445 dcp::Time (0, 0, 0, 0, 250),
446 dcp::Time (0, 0, 0, 0, 250)
448 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
451 dcp::Colour (255, 255, 255),
454 dcp::Time (0, 1, 47, 146, 250),
455 dcp::Time (0, 1, 48, 167, 250),
462 dcp::Colour (0, 0, 0),
463 dcp::Time (0, 0, 0, 0, 250),
464 dcp::Time (0, 0, 0, 0, 250)
467 s = subs.subtitles_during (dcp::Time (0, 2, 6, 210, 250), dcp::Time (0, 2, 6, 211, 250), false);
468 BOOST_REQUIRE_EQUAL (s.size(), 2);
469 BOOST_CHECK_EQUAL (s.front(), dcp::SubtitleString (
472 dcp::Colour (255, 255, 255),
475 dcp::Time (0, 2, 5, 208, 250),
476 dcp::Time (0, 2, 7, 31, 250),
483 dcp::Colour (0, 0, 0),
484 dcp::Time (0, 0, 0, 0, 250),
485 dcp::Time (0, 0, 0, 0, 250)
487 BOOST_CHECK_EQUAL (s.back(), dcp::SubtitleString (
490 dcp::Colour (255, 255, 255),
493 dcp::Time (0, 2, 5, 208, 250),
494 dcp::Time (0, 2, 7, 31, 250),
501 dcp::Colour (0, 0, 0),
502 dcp::Time (0, 0, 0, 0, 250),
503 dcp::Time (0, 0, 0, 0, 250)