}
}
+ if (dcp->standard() == dcp::SMPTE) {
+ boost::optional<int64_t> duration;
+ for (auto i: reel->assets()) {
+ if (!duration) {
+ duration = i->actual_duration();
+ } else if (*duration != i->actual_duration()) {
+ notes.push_back (VerificationNote(VerificationNote::VERIFY_BV21_ERROR, VerificationNote::MISMATCHED_ASSET_DURATION, i->id()));
+ break;
+ }
+ }
+ }
+
if (reel->main_picture()) {
/* Check reel stuff */
auto const frame_rate = reel->main_picture()->frame_rate();
return "The CPL has no <AnnotationText> tag, which is required by Bv2.1";
case dcp::VerificationNote::CPL_ANNOTATION_TEXT_DIFFERS_FROM_CONTENT_TITLE_TEXT:
return "The CPL's <AnnotationText> differs from its <ContentTitleText>, which Bv2.1 advises against.";
+ case dcp::VerificationNote::MISMATCHED_ASSET_DURATION:
+ return "All assets in a reel do not have the same duration, which is required by Bv2.1";
}
return "";
shared_ptr<dcp::DCP>
make_simple_with_smpte_subs (boost::filesystem::path path)
{
- shared_ptr<dcp::DCP> dcp = make_simple (path);
+ shared_ptr<dcp::DCP> dcp = make_simple (path, 1, 240);
shared_ptr<dcp::SMPTESubtitleAsset> subs(new dcp::SMPTESubtitleAsset());
subs->set_language (dcp::LanguageTag("de-DE"));
shared_ptr<dcp::DCP>
make_simple_with_smpte_ccaps (boost::filesystem::path path)
{
- shared_ptr<dcp::DCP> dcp = make_simple (path);
+ shared_ptr<dcp::DCP> dcp = make_simple (path, 1, 240);
shared_ptr<dcp::SMPTESubtitleAsset> subs(new dcp::SMPTESubtitleAsset());
subs->set_language (dcp::LanguageTag("de-DE"));
{
boost::filesystem::path dir = "build/test/verify_missing_language_tag_in_subtitle_xml";
prepare_directory (dir);
- auto dcp = make_simple (dir, 1);
+ auto dcp = make_simple (dir, 1, 240);
string const xml =
"<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
auto subs = make_shared<dcp::SMPTESubtitleAsset>(dir / "subs.xml");
subs->write (dir / "subs.mxf");
- auto reel_subs = make_shared<dcp::ReelSubtitleAsset>(subs, dcp::Fraction(24, 1), 100, 0);
+ auto reel_subs = make_shared<dcp::ReelSubtitleAsset>(subs, dcp::Fraction(24, 1), 240, 0);
dcp->cpls().front()->reels().front()->add(reel_subs);
dcp->write_xml (dcp::SMPTE);
{
boost::filesystem::path dir = "build/test/verify_missing_start_time_tag_in_subtitle_xml";
prepare_directory (dir);
- auto dcp = make_simple (dir, 1);
+ auto dcp = make_simple (dir, 1, 240);
string const xml =
"<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
auto subs = make_shared<dcp::SMPTESubtitleAsset>(dir / "subs.xml");
subs->write (dir / "subs.mxf");
- auto reel_subs = make_shared<dcp::ReelSubtitleAsset>(subs, dcp::Fraction(24, 1), 100, 0);
+ auto reel_subs = make_shared<dcp::ReelSubtitleAsset>(subs, dcp::Fraction(24, 1), 240, 0);
dcp->cpls().front()->reels().front()->add(reel_subs);
dcp->write_xml (dcp::SMPTE);
{
boost::filesystem::path dir = "build/test/verify_non_zero_start_time_tag_in_subtitle_xml";
prepare_directory (dir);
- auto dcp = make_simple (dir, 1);
+ auto dcp = make_simple (dir, 1, 240);
string const xml =
"<?xml version=\"1.0\" encoding=\"UTF-8\"?>"
auto subs = make_shared<dcp::SMPTESubtitleAsset>(dir / "subs.xml");
subs->write (dir / "subs.mxf");
- auto reel_subs = make_shared<dcp::ReelSubtitleAsset>(subs, dcp::Fraction(24, 1), 100, 0);
+ auto reel_subs = make_shared<dcp::ReelSubtitleAsset>(subs, dcp::Fraction(24, 1), 240, 0);
dcp->cpls().front()->reels().front()->add(reel_subs);
dcp->write_xml (dcp::SMPTE);
});
}
+
+BOOST_AUTO_TEST_CASE (verify_reel_assets_durations_must_match)
+{
+ boost::filesystem::path const dir("build/test/verify_reel_assets_durations_must_match");
+ boost::filesystem::remove_all (dir);
+ boost::filesystem::create_directories (dir);
+ shared_ptr<dcp::DCP> dcp (new dcp::DCP(dir));
+ shared_ptr<dcp::CPL> cpl (new dcp::CPL("A Test DCP", dcp::FEATURE));
+
+ shared_ptr<dcp::MonoPictureAsset> mp = simple_picture (dir, "", 24);
+ shared_ptr<dcp::SoundAsset> ms = simple_sound (dir, "", dcp::MXFMetadata(), "en-US", 25);
+
+ cpl->add (
+ make_shared<dcp::Reel>(
+ make_shared<dcp::ReelMonoPictureAsset>(mp, 0),
+ make_shared<dcp::ReelSoundAsset>(ms, 0)
+ )
+ );
+
+ dcp->add (cpl);
+ dcp->write_xml (dcp::SMPTE);
+
+ check_verify_result ({dir}, {{ dcp::VerificationNote::VERIFY_BV21_ERROR, dcp::VerificationNote::MISMATCHED_ASSET_DURATION }});
+}
+