X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Ffilm_metadata_test.cc;h=9b855de5b5c355e56918a904424b39834d5798d6;hb=182b9d2e2feb6545592868606aaf0f0146095481;hp=feee58dc291e5fb3ec172487f5160ffa448660f5;hpb=175e882d1d9d56e759ad613ce678cad70d13f8ed;p=dcpomatic.git diff --git a/test/film_metadata_test.cc b/test/film_metadata_test.cc index feee58dc2..9b855de5b 100644 --- a/test/film_metadata_test.cc +++ b/test/film_metadata_test.cc @@ -32,6 +32,7 @@ #include "lib/film.h" #include "lib/ratio.h" #include "lib/text_content.h" +#include "lib/video_content.h" #include "test.h" #include #include @@ -82,8 +83,8 @@ BOOST_AUTO_TEST_CASE (film_metadata_test) /** Check a bug where tags with multiple s would fail to load */ BOOST_AUTO_TEST_CASE (multiple_text_nodes_are_allowed) { - auto subs = content_factory("test/data/15s.srt").front(); - auto caps = content_factory("test/data/15s.srt").front(); + auto subs = content_factory("test/data/15s.srt")[0]; + auto caps = content_factory("test/data/15s.srt")[0]; auto film = new_test_film2("multiple_text_nodes_are_allowed1", { subs, caps }); caps->only_text()->set_type(TextType::CLOSED_CAPTION); make_and_verify_dcp ( @@ -160,3 +161,52 @@ BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_3) BOOST_REQUIRE (film->luminance() == dcp::Luminance(14, dcp::Luminance::Unit::FOOT_LAMBERT)); } + +/** Check that an empty tag results in the film's luminance being unset */ +BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_4) +{ + namespace fs = boost::filesystem; + auto dir = fs::path("build/test/metadata_loads_from_2_14_x_4"); + fs::remove_all(dir); + auto film = make_shared(dir); + fs::copy_file("test/data/2.14.x.metadata.4.xml", dir / "metadata.xml"); + auto notes = film->read_metadata(dir / "metadata.xml"); + + BOOST_REQUIRE (!film->luminance()); +} + + +BOOST_AUTO_TEST_CASE (metadata_video_range_guessed_for_dcp) +{ + namespace fs = boost::filesystem; + auto film = make_shared(fs::path("test/data/214x_dcp")); + film->read_metadata(); + + BOOST_REQUIRE_EQUAL(film->content().size(), 1U); + BOOST_REQUIRE(film->content()[0]->video); + BOOST_CHECK(film->content()[0]->video->range() == VideoRange::FULL); +} + + +BOOST_AUTO_TEST_CASE (metadata_video_range_guessed_for_mp4_with_unknown_range) +{ + namespace fs = boost::filesystem; + auto film = make_shared(fs::path("test/data/214x_mp4")); + film->read_metadata(); + + BOOST_REQUIRE_EQUAL(film->content().size(), 1U); + BOOST_REQUIRE(film->content()[0]->video); + BOOST_CHECK(film->content()[0]->video->range() == VideoRange::VIDEO); +} + + +BOOST_AUTO_TEST_CASE (metadata_video_range_guessed_for_png) +{ + namespace fs = boost::filesystem; + auto film = make_shared(fs::path("test/data/214x_png")); + film->read_metadata(); + + BOOST_REQUIRE_EQUAL(film->content().size(), 1U); + BOOST_REQUIRE(film->content()[0]->video); + BOOST_CHECK(film->content()[0]->video->range() == VideoRange::FULL); +}