/* Copyright (C) 2021 Carl Hetherington This file is part of DCP-o-matic. DCP-o-matic 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. DCP-o-matic 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 DCP-o-matic. If not, see . */ #include "lib/audio_buffers.h" #include "lib/content.h" #include "lib/content_factory.h" #include "lib/cross.h" #include "lib/film.h" #include "lib/job.h" #include "lib/video_content.h" #include "lib/writer.h" #include "test.h" #include #include #include #include using std::make_shared; using std::shared_ptr; using std::vector; BOOST_AUTO_TEST_CASE (test_write_odd_amount_of_silence) { auto content = content_factory("test/data/flat_red.png"); auto film = new_test_film2 ("test_write_odd_amount_of_silence", content); content[0]->video->set_length(24); auto writer = make_shared(film, shared_ptr()); auto audio = make_shared(6, 48000); audio->make_silent (); writer->write (audio, dcpomatic::DCPTime(1)); } BOOST_AUTO_TEST_CASE (interrupt_writer) { Cleanup cl; auto film = new_test_film2 ("test_interrupt_writer", {}, &cl); auto content = content_factory("test/data/check_image0.png")[0]; film->examine_and_add_content (content); BOOST_REQUIRE (!wait_for_jobs()); /* Add some dummy content to the film so that it has a reel of the right length */ auto constexpr frames = 24 * 60; content->video->set_length (frames); /* Make a random J2K image */ auto size = dcp::Size(1998, 1080); auto image = make_shared(size); for (int i = 0; i < 3; ++i) { for (int j = 0; j < (size.width * size.height); ++j) { image->data(i)[j] = rand(); } } /* Write some data */ auto video = dcp::compress_j2k(image, 100000000, 24, false, false); auto video_ptr = make_shared(video.data(), video.size()); auto audio = make_shared(6, 48000 / 24); auto writer = make_shared(film, shared_ptr()); writer->start (); for (int i = 0; i < frames; ++i) { writer->write (video_ptr, i, Eyes::BOTH); writer->write (audio, dcpomatic::DCPTime::from_frames(i, 24)); } /* Start digest calculations then abort them; there should be no crash or error */ boost::thread thread([film, writer]() { writer->finish(film->dir(film->dcp_name())); }); dcpomatic_sleep_seconds (1); thread.interrupt (); thread.join (); dcpomatic_sleep_seconds (1); cl.run (); } BOOST_AUTO_TEST_CASE (writer_disambiguate_font_ids1) { auto film = new_test_film2("writer_disambiguate_font_ids1", {}); Writer writer(film, {}); auto fonts = vector> { make_shared("a"), make_shared("b"), make_shared("c") }; writer.write(fonts); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[0]), "a"); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[1]), "b"); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[2]), "c"); } BOOST_AUTO_TEST_CASE (writer_disambiguate_font_ids2) { auto film = new_test_film2("writer_disambiguate_font_ids2", {}); Writer writer(film, {}); auto fonts = vector> { make_shared("a"), make_shared("a"), make_shared("a") }; writer.write(fonts); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[0]), "a"); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[1]), "a_0"); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[2]), "a_1"); } BOOST_AUTO_TEST_CASE (writer_disambiguate_font_ids3) { auto film = new_test_film2("writer_disambiguate_font_ids3", {}); Writer writer(film, {}); auto fonts = vector> { make_shared("a_2"), make_shared("a_1"), make_shared("a_1"), make_shared("b") }; writer.write(fonts); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[1]), "a_1"); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[0]), "a_2"); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[2]), "a_3"); BOOST_CHECK_EQUAL(writer._fonts.get(fonts[3]), "b"); }