X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fdecryption_test.cc;h=77f349bd1940c30937ef9df8e3b0c79fd13fece1;hb=d4f883f7e88b93d1ec2d451036f2b85434baff13;hp=282e74f391ad0ad63fd80374a59e44038397fcec;hpb=989f182558193a51e0a26603fb2ca59f827216a0;p=libdcp.git diff --git a/test/decryption_test.cc b/test/decryption_test.cc index 282e74f3..77f349bd 100644 --- a/test/decryption_test.cc +++ b/test/decryption_test.cc @@ -1,20 +1,34 @@ /* - Copyright (C) 2013-2014 Carl Hetherington + Copyright (C) 2013-2019 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of libdcp. + + libdcp 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, + libdcp 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 libdcp. If not, see . + + In addition, as a special exception, the copyright holders give + permission to link the code of portions of this program with the + OpenSSL library under certain conditions as described in each + individual source file, and distribute linked combinations + including the two. + + You must obey the GNU General Public License in all respects + for all of the code used other than OpenSSL. If you modify + file(s) with this exception, you may extend this exception to your + version of the file(s), but you are not obligated to do so. If you + do not wish to do so, delete this exception statement from your + version. If you delete this exception statement from all source + files in the program, then also delete it here. */ #include "dcp.h" @@ -22,35 +36,38 @@ #include "cpl.h" #include "decrypted_kdm.h" #include "encrypted_kdm.h" -#include "mono_picture_mxf.h" +#include "mono_picture_asset.h" +#include "mono_picture_asset_reader.h" #include "reel_picture_asset.h" #include "reel.h" #include "test.h" -#include "xyz_image.h" +#include "openjpeg_image.h" #include "rgb_xyz.h" #include "colour_conversion.h" +#include "stream_operators.h" #include #include using std::pair; using std::make_pair; -using boost::dynamic_pointer_cast; -using boost::shared_ptr; +using std::dynamic_pointer_cast; +using std::shared_ptr; using boost::scoped_array; pair get_frame (dcp::DCP const & dcp) { shared_ptr reel = dcp.cpls().front()->reels().front (); - shared_ptr picture = reel->main_picture()->mxf (); + shared_ptr picture = reel->main_picture()->asset (); BOOST_CHECK (picture); - shared_ptr mono_picture = dynamic_pointer_cast (picture); - shared_ptr j2k_frame = mono_picture->get_frame (0); - shared_ptr xyz = j2k_frame->xyz_image(); + shared_ptr mono_picture = dynamic_pointer_cast (picture); + shared_ptr reader = mono_picture->start_read (); + shared_ptr j2k_frame = reader->get_frame (0); + shared_ptr xyz = j2k_frame->xyz_image(); uint8_t* argb = new uint8_t[xyz->size().width * xyz->size().height * 4]; - dcp::xyz_to_rgba (j2k_frame->xyz_image(), dcp::ColourConversion::xyz_to_srgb(), argb); + dcp::xyz_to_rgba (j2k_frame->xyz_image(), dcp::ColourConversion::srgb_to_xyz(), argb, xyz->size().width * 4); return make_pair (argb, xyz->size ()); } @@ -61,13 +78,13 @@ BOOST_AUTO_TEST_CASE (decryption_test) plaintext_path /= "TONEPLATES-SMPTE-PLAINTEXT_TST_F_XX-XX_ITL-TD_51-XX_2K_WOE_20111001_WOE_OV"; dcp::DCP plaintext (plaintext_path.string ()); plaintext.read (); - BOOST_CHECK_EQUAL (plaintext.encrypted (), false); + BOOST_CHECK_EQUAL (plaintext.any_encrypted(), false); boost::filesystem::path encrypted_path = private_test; encrypted_path /= "TONEPLATES-SMPTE-ENCRYPTED_TST_F_XX-XX_ITL-TD_51-XX_2K_WOE_20111001_WOE_OV"; dcp::DCP encrypted (encrypted_path.string ()); encrypted.read (); - BOOST_CHECK_EQUAL (encrypted.encrypted (), true); + BOOST_CHECK_EQUAL (encrypted.any_encrypted(), true); dcp::DecryptedKDM kdm ( dcp::EncryptedKDM ( @@ -75,7 +92,7 @@ BOOST_AUTO_TEST_CASE (decryption_test) ), dcp::file_to_string ("test/data/private.key") ); - + encrypted.add (kdm); pair plaintext_frame = get_frame (plaintext); @@ -84,7 +101,7 @@ BOOST_AUTO_TEST_CASE (decryption_test) /* Check that plaintext and encrypted are the same */ BOOST_CHECK_EQUAL (plaintext_frame.second, encrypted_frame.second); - + BOOST_CHECK_EQUAL ( memcmp ( plaintext_frame.first,