X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Frecover_test.cc;h=95e45e08bf9c4439ee229638d5b78fb0b6d77d77;hb=d0a0a4839f0e1e8d37f9f9ad41784c4d18210a6b;hp=3b31a6f8df1a08a099b0e8c02e58e4ad03ad1dd3;hpb=17553e8613a83bbca51781e5c8d2308810e2aeeb;p=dcpomatic.git diff --git a/test/recover_test.cc b/test/recover_test.cc index 3b31a6f8d..95e45e08b 100644 --- a/test/recover_test.cc +++ b/test/recover_test.cc @@ -1,24 +1,26 @@ /* Copyright (C) 2014-2015 Carl Hetherington - This program is free software; you can redistribute it and/or modify + 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. - This program is distributed in the hope that it will be useful, + 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 this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ /** @file test/recover_test.cc * @brief Test recovery of a DCP transcode after a crash. + * @ingroup specific */ #include "test.h" @@ -26,6 +28,7 @@ #include "lib/dcp_content_type.h" #include "lib/image_content.h" #include "lib/ffmpeg_content.h" +#include "lib/video_content.h" #include "lib/ratio.h" #include #include @@ -58,8 +61,7 @@ BOOST_AUTO_TEST_CASE (recover_test_2d) film->make_dcp (); wait_for_jobs (); - boost::filesystem::path const video = "build/test/recover_test_2d/video/185_2K_d2b23c22cff43b0247c7108dcd32323c_24_100000000_P_S.mxf"; - + boost::filesystem::path const video = "build/test/recover_test_2d/video/185_2K_517799e697fdd13033f9f7e836e7dc43_24_100000000_P_S_0_1200000.mxf"; boost::filesystem::copy_file ( video, "build/test/recover_test_2d/original.mxf" @@ -86,14 +88,14 @@ BOOST_AUTO_TEST_CASE (recover_test_3d) film->set_three_d (true); shared_ptr content (new ImageContent (film, "test/data/3d_test")); - content->set_video_frame_type (VIDEO_FRAME_TYPE_3D_LEFT_RIGHT); + content->video->set_frame_type (VIDEO_FRAME_TYPE_3D_LEFT_RIGHT); film->examine_and_add_content (content); wait_for_jobs (); film->make_dcp (); wait_for_jobs (); - boost::filesystem::path const video = "build/test/recover_test_3d/video/185_2K_961f053444e90c5ddbf978eb0ebfa772_24_100000000_P_S_3D.mxf"; + boost::filesystem::path const video = "build/test/recover_test_3d/video/185_2K_961f053444e90c5ddbf978eb0ebfa772_24_100000000_P_S_3D_0_96000.mxf"; boost::filesystem::copy_file ( video, @@ -111,3 +113,41 @@ BOOST_AUTO_TEST_CASE (recover_test_3d) dcp::EqualityOptions eq; BOOST_CHECK (A->equals (B, eq, boost::bind (¬e, _1, _2))); } + + +BOOST_AUTO_TEST_CASE (recover_test_2d_encrypted) +{ + shared_ptr film = new_test_film ("recover_test_2d_encrypted"); + film->set_dcp_content_type (DCPContentType::from_isdcf_name ("FTR")); + film->set_container (Ratio::from_id ("185")); + film->set_name ("recover_test"); + film->set_encrypted (true); + + shared_ptr content (new FFmpegContent (film, "test/data/count300bd24.m2ts")); + film->examine_and_add_content (content); + wait_for_jobs (); + + film->make_dcp (); + wait_for_jobs (); + + boost::filesystem::path const video = + "build/test/recover_test_2d_encrypted/video/185_2K_517799e697fdd13033f9f7e836e7dc43_24_100000000_E_S_0_1200000.mxf"; + + boost::filesystem::copy_file ( + video, + "build/test/recover_test_2d_encrypted/original.mxf" + ); + + boost::filesystem::resize_file (video, 2 * 1024 * 1024); + + film->make_dcp (); + wait_for_jobs (); + + shared_ptr A (new dcp::MonoPictureAsset ("build/test/recover_test_2d_encrypted/original.mxf")); + A->set_key (film->key ()); + shared_ptr B (new dcp::MonoPictureAsset (video)); + B->set_key (film->key ()); + + dcp::EqualityOptions eq; + BOOST_CHECK (A->equals (B, eq, boost::bind (¬e, _1, _2))); +}