X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fj2k_bandwidth_test.cc;h=1825051070dfca0ec933a3b64fb02bc209b90253;hb=450602739388811a6378314d6c309b99f7b28b60;hp=ed8f5d9c8d523e18464b7d0522503fdc52234feb;hpb=e756452872422f948b06376ccfd07dfe5bc86969;p=dcpomatic.git diff --git a/test/j2k_bandwidth_test.cc b/test/j2k_bandwidth_test.cc index ed8f5d9c8..182505107 100644 --- a/test/j2k_bandwidth_test.cc +++ b/test/j2k_bandwidth_test.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2016 Carl Hetherington + Copyright (C) 2016-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,6 +18,13 @@ */ + +/** @file test/bandwidth_test.cc + * @brief Test whether we output whatever J2K bandwidth is requested. + * @ingroup feature + */ + + #include "test.h" #include "lib/dcp_content_type.h" #include "lib/film.h" @@ -25,31 +32,38 @@ #include "lib/video_content.h" #include #include -#include + +using std::make_shared; using std::string; -using boost::shared_ptr; +using std::shared_ptr; + static void check (int target_bits_per_second) { int const duration = 10; - string const name = "j2k_bandwidth_test_" + dcp::raw_convert (target_bits_per_second); - shared_ptr film = new_test_film (name); + string const name = "bandwidth_test_" + dcp::raw_convert (target_bits_per_second); + auto film = new_test_film (name); film->set_name (name); film->set_dcp_content_type (DCPContentType::from_isdcf_name ("FTR")); film->set_j2k_bandwidth (target_bits_per_second); - shared_ptr content (new ImageContent (film, private_data / "prophet_frame.tiff")); + auto content = make_shared(TestPaths::private_data() / "prophet_frame.tiff"); film->examine_and_add_content (content); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); content->video->set_length (24 * duration); - film->make_dcp (); - wait_for_jobs (); + make_and_verify_dcp ( + film, + { + dcp::VerificationNote::Code::MISSING_FFMC_IN_FEATURE, + dcp::VerificationNote::Code::MISSING_FFEC_IN_FEATURE, + dcp::VerificationNote::Code::NEARLY_INVALID_PICTURE_FRAME_SIZE_IN_BYTES + }); - boost::filesystem::directory_iterator i (boost::filesystem::path ("build") / "test" / name / "video"); + boost::filesystem::directory_iterator i (boost::filesystem::path("build") / "test" / name / "video"); boost::filesystem::path test = *i++; - BOOST_REQUIRE (i == boost::filesystem::directory_iterator ()); + BOOST_REQUIRE (i == boost::filesystem::directory_iterator()); double actual_bits_per_second = boost::filesystem::file_size(test) * 8.0 / duration; @@ -58,7 +72,8 @@ check (int target_bits_per_second) BOOST_CHECK ((actual_bits_per_second / target_bits_per_second) < 1.15); } -BOOST_AUTO_TEST_CASE (j2k_bandwidth_test) + +BOOST_AUTO_TEST_CASE (bandwidth_test) { check (50000000); check (100000000);