/* Copyright (C) 2016 Carl Hetherington This program 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. This program 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 this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "test.h" #include "ssa_reader.h" #include "collect.h" #include "subtitle.h" #include #include #include using std::list; BOOST_AUTO_TEST_CASE (ssa_reader_test) { boost::filesystem::path p = private_test / "example.ssa"; FILE* f = fopen (p.string().c_str(), "r"); sub::SSAReader reader (f); fclose (f); list subs = sub::collect > (reader.subtitles ()); list::iterator i = subs.begin (); BOOST_REQUIRE (i != subs.end ()); BOOST_CHECK_EQUAL (i->from, sub::Time::from_hms (0, 2, 40, 650)); BOOST_CHECK_EQUAL (i->to, sub::Time::from_hms (0, 2, 41, 790)); list::iterator j = i->lines.begin(); BOOST_REQUIRE (j != i->lines.end ()); BOOST_CHECK_EQUAL (j->vertical_position.proportional.get(), 0); BOOST_CHECK_EQUAL (j->vertical_position.reference.get(), sub::BOTTOM_OF_SCREEN); BOOST_REQUIRE_EQUAL (j->blocks.size(), 1); sub::Block b = j->blocks.front (); BOOST_CHECK_EQUAL (b.text, "Et les enregistrements de ses ondes delta ?"); BOOST_CHECK_EQUAL (b.font.get(), "Wolf_Rain"); BOOST_CHECK_EQUAL (b.font_size.proportional().get(), 56.0 / 1024); BOOST_CHECK_EQUAL (b.bold, false); BOOST_CHECK_EQUAL (b.italic, false); BOOST_CHECK_EQUAL (b.underline, false); ++i; BOOST_REQUIRE (i != subs.end ()); BOOST_CHECK_EQUAL (i->from, sub::Time::from_hms (0, 2, 42, 420)); BOOST_CHECK_EQUAL (i->to, sub::Time::from_hms (0, 2, 44, 150)); j = i->lines.begin(); BOOST_REQUIRE (j != i->lines.end ()); BOOST_REQUIRE_EQUAL (j->blocks.size(), 1); b = j->blocks.front (); BOOST_CHECK_EQUAL (b.text, "Toujours rien."); BOOST_CHECK_EQUAL (b.font.get(), "Wolf_Rain"); BOOST_CHECK_EQUAL (b.font_size.proportional().get(), 56.0 / 1024); BOOST_CHECK_EQUAL (b.bold, false); BOOST_CHECK_EQUAL (b.italic, false); BOOST_CHECK_EQUAL (b.underline, false); ++i; BOOST_CHECK (i == subs.end()); } static void test (boost::filesystem::path p) { p = private_test / p; FILE* f = fopen (p.string().c_str(), "r"); BOOST_REQUIRE (f); sub::SSAReader r (f); fclose (f); } /** Test of reading some typical .srt files */ BOOST_AUTO_TEST_CASE (ssa_reader_test2) { test ("DKH_UT_EN20160601def.ssa"); } /** Test a file with some bits to exercise the parser */ BOOST_AUTO_TEST_CASE (ssa_reader_test3) { boost::filesystem::path p = "test/data/test.ssa"; FILE* f = fopen (p.string().c_str(), "r"); sub::SSAReader reader (f); fclose (f); list subs = sub::collect > (reader.subtitles ()); BOOST_REQUIRE_EQUAL (subs.size(), 2); list::const_iterator i = subs.begin (); BOOST_CHECK_EQUAL (i->from, sub::Time::from_hms (0, 0, 1, 230)); BOOST_CHECK_EQUAL (i->to, sub::Time::from_hms (0, 0, 4, 550)); BOOST_REQUIRE_EQUAL (i->lines.size(), 1); list::const_iterator j = i->lines.begin(); BOOST_REQUIRE_EQUAL (j->blocks.size(), 1); sub::Block b = j->blocks.front (); BOOST_CHECK_EQUAL (b.text, "Hello world"); ++i; BOOST_CHECK_EQUAL (i->from, sub::Time::from_hms (0, 0, 5, 740)); BOOST_CHECK_EQUAL (i->to, sub::Time::from_hms (0, 0, 11, 0)); BOOST_REQUIRE_EQUAL (i->lines.size(), 1); j = i->lines.begin(); BOOST_REQUIRE_EQUAL (j->blocks.size(), 1); b = j->blocks.front (); BOOST_CHECK_EQUAL (b.text, "This is vertically moved"); ++i; }