summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2024-02-21 01:10:23 +0100
committerCarl Hetherington <cth@carlh.net>2024-02-21 01:27:31 +0100
commita9b1c1cb65e1902a64430977cf698054e131a6f4 (patch)
tree08b654773e87e94bd38f9f2c3ca3a380d7c3e476
parent10932722619696f1e089723c2dccf51281f24a40 (diff)
Fix failure to examine non-flat-ratio VFs (#2775).
-rw-r--r--src/lib/audio_examiner.h4
-rw-r--r--src/lib/dcp_examiner.cc2
-rw-r--r--test/dcp_examiner_test.cc52
-rw-r--r--test/wscript1
4 files changed, 57 insertions, 2 deletions
diff --git a/src/lib/audio_examiner.h b/src/lib/audio_examiner.h
index f18387041..8f5646d0f 100644
--- a/src/lib/audio_examiner.h
+++ b/src/lib/audio_examiner.h
@@ -21,6 +21,10 @@
#ifndef DCPOMATIC_AUDIO_EXAMINER_H
#define DCPOMATIC_AUDIO_EXAMINER_H
+
+#include "types.h"
+
+
/** @file src/lib/audio_examiner.h
* @brief AudioExaminer class.
*/
diff --git a/src/lib/dcp_examiner.cc b/src/lib/dcp_examiner.cc
index 72eb82860..88c9a5b70 100644
--- a/src/lib/dcp_examiner.cc
+++ b/src/lib/dcp_examiner.cc
@@ -145,8 +145,6 @@ DCPExaminer::DCPExaminer (shared_ptr<const DCPContent> content, bool tolerant)
if (!reel->main_picture()->asset_ref().resolved()) {
LOG_GENERAL("Main picture %1 of reel %2 is missing", reel->main_picture()->id(), reel->id());
_needs_assets = true;
- /* Use a dummy value here; it will be replaced when the VF is re-examined. */
- _video_size = dcp::Size(1998, 1080);
} else {
LOG_GENERAL("Main picture %1 of reel %2 found", reel->main_picture()->id(), reel->id());
diff --git a/test/dcp_examiner_test.cc b/test/dcp_examiner_test.cc
new file mode 100644
index 000000000..cdd6b20f1
--- /dev/null
+++ b/test/dcp_examiner_test.cc
@@ -0,0 +1,52 @@
+/*
+ Copyright (C) 2024 Carl Hetherington <cth@carlh.net>
+
+ 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 <http://www.gnu.org/licenses/>.
+
+*/
+
+
+#include "lib/content_factory.h"
+#include "lib/dcp_content.h"
+#include "lib/dcp_examiner.h"
+#include "lib/film.h"
+#include "lib/ratio.h"
+#include "test.h"
+#include <boost/test/unit_test.hpp>
+
+
+using std::make_shared;
+
+
+BOOST_AUTO_TEST_CASE(check_examine_vfs)
+{
+ auto image = content_factory("test/data/scope_red.png")[0];
+ auto ov = new_test_film2("check_examine_vfs_ov", { image });
+ ov->set_container(Ratio::from_id("239"));
+ make_and_verify_dcp(ov);
+
+ auto ov_dcp = make_shared<DCPContent>(ov->dir(ov->dcp_name()));
+ auto second_reel = content_factory("test/data/scope_red.png")[0];
+ auto vf = new_test_film2("check_examine_vf_vf", { ov_dcp, second_reel });
+ vf->set_container(Ratio::from_id("239"));
+ vf->set_reel_type(ReelType::BY_VIDEO_CONTENT);
+ ov_dcp->set_reference_video(true);
+ make_and_verify_dcp(vf, { dcp::VerificationNote::Code::EXTERNAL_ASSET });
+
+ auto vf_dcp = make_shared<DCPContent>(vf->dir(vf->dcp_name()));
+ DCPExaminer examiner(vf_dcp, false);
+}
+
diff --git a/test/wscript b/test/wscript
index a98f15d5b..bb66d1a5f 100644
--- a/test/wscript
+++ b/test/wscript
@@ -73,6 +73,7 @@ def build(bld):
dcpomatic_time_test.cc
dcp_decoder_test.cc
dcp_digest_file_test.cc
+ dcp_examiner_test.cc
dcp_metadata_test.cc
dcp_playback_test.cc
dcp_subtitle_test.cc