X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fffmpeg_dcp_test.cc;h=ce8ecad6bfcfa7a2fffe708f82aca99ba6e84c93;hb=e60bb3e51bd1508b149e6b8f6608f09b5196ae26;hp=88b1e94af063de1ef394bd85afcebc39c69ee918;hpb=a79d78d8bb6d51f6662f1f63b9f8fd19e1a0c5f1;p=dcpomatic.git diff --git a/test/ffmpeg_dcp_test.cc b/test/ffmpeg_dcp_test.cc index 88b1e94af..ce8ecad6b 100644 --- a/test/ffmpeg_dcp_test.cc +++ b/test/ffmpeg_dcp_test.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2014 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 @@ -17,8 +17,15 @@ */ +/** @file test/ffmpeg_dcp_test.cc + * @brief Test creation of a very simple DCP from some FFmpegContent (data/test.mp4). + * + * Also a quick test of Film::have_dcp (). + */ + #include #include +#include #include "lib/film.h" #include "lib/ffmpeg_content.h" #include "lib/ratio.h" @@ -27,20 +34,17 @@ using boost::shared_ptr; -/** @file test/ffmpeg_dcp_test.cc - * @brief Test scaling and black-padding of images from a still-image source. - */ - BOOST_AUTO_TEST_CASE (ffmpeg_dcp_test) { shared_ptr film = new_test_film ("ffmpeg_dcp_test"); film->set_name ("test_film2"); shared_ptr c (new FFmpegContent (film, "test/data/test.mp4")); - c->set_scale (VideoContentScale (Ratio::from_id ("185"))); film->examine_and_add_content (c); wait_for_jobs (); - + + c->set_scale (VideoContentScale (Ratio::from_id ("185"))); + film->set_container (Ratio::from_id ("185")); film->set_dcp_content_type (DCPContentType::from_pretty_name ("Test")); film->make_dcp (); @@ -49,16 +53,23 @@ BOOST_AUTO_TEST_CASE (ffmpeg_dcp_test) wait_for_jobs (); } -/** Test Film::have_dcp(). Requires the output from ffmpeg_dcp_test above */ +/** Briefly test Film::cpls(). Requires the output from ffmpeg_dcp_test above */ BOOST_AUTO_TEST_CASE (ffmpeg_have_dcp_test) { boost::filesystem::path p = test_film_dir ("ffmpeg_dcp_test"); - shared_ptr f (new Film (p.string ())); - f->read_metadata (); - BOOST_CHECK (!f->dcps().empty()); - - p /= f->dcp_name(); - p /= f->video_mxf_filename(); - boost::filesystem::remove (p); - BOOST_CHECK (f->dcps().empty()); + shared_ptr film (new Film (p.string ())); + film->read_metadata (); + BOOST_CHECK (!film->cpls().empty()); + + p /= film->dcp_name(); + boost::filesystem::directory_iterator i = boost::filesystem::directory_iterator (p); + while (i != boost::filesystem::directory_iterator() && !boost::algorithm::starts_with (i->path().leaf().string(), "j2c")) { + ++i; + } + + if (i != boost::filesystem::directory_iterator ()) { + boost::filesystem::remove (i->path ()); + } + + BOOST_CHECK (film->cpls().empty()); }