X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=test%2Ftest.cc;h=edeb89925dd7d2bbe599b26d4c34873dfa9d92d3;hb=1d7a98b5c7537b4874645c56cd83ece9f78625f5;hp=081a13a8cd93e07de09e5f25034dfa3c6e8c5ed5;hpb=ba7516b01ddef143d58b32ac14350dcd15079641;p=dcpomatic.git diff --git a/test/test.cc b/test/test.cc index 081a13a8c..edeb89925 100644 --- a/test/test.cc +++ b/test/test.cc @@ -236,7 +236,15 @@ check_image (boost::filesystem::path ref, boost::filesystem::path check) ref_image.read (ref.string ()); Magick::Image check_image; check_image.read (check.string ()); - BOOST_CHECK_MESSAGE (ref_image.compare (check_image), ref << " differs from " << check); + /* XXX: this is a hack; we really want the ImageMagick call but GraphicsMagick doesn't have it; + this may cause random test failures on platforms that use GraphicsMagick. + */ +#ifdef DCPOMATIC_ADVANCED_MAGICK_COMPARE + double const dist = ref_image.compare(check_image, Magick::RootMeanSquaredErrorMetric); + BOOST_CHECK_MESSAGE (dist < 0.001, ref << " differs from " << check << " " << dist); +#else + BOOST_CHECK_MESSAGE (!ref_image.compare(check_image), ref << " differs from " << check); +#endif } void @@ -422,30 +430,11 @@ write_image (shared_ptr image, boost::filesystem::path file, string m.write (file.string ()); } -static -void -check_ffmpeg_stream (boost::filesystem::path ref, boost::filesystem::path check, string stream) -{ - FILE* ref_file = popen(string("ffmpeg -loglevel error -i " + ref.string() + " -map 0:" + stream + " -f md5 -").c_str(), "r"); - BOOST_REQUIRE (ref_file); - char ref_md5[64]; - fscanf (ref_file, "%63s", ref_md5); - pclose (ref_file); - - FILE* check_file = popen(string("ffmpeg -loglevel error -i " + check.string() + " -map 0:" + stream + " -f md5 -").c_str(), "r"); - BOOST_REQUIRE (check_file); - char check_md5[64]; - fscanf (check_file, "%63s", check_md5); - pclose (check_file); - - BOOST_REQUIRE_EQUAL (strcmp(ref_md5, check_md5), 0); -} - void check_ffmpeg (boost::filesystem::path ref, boost::filesystem::path check) { - check_ffmpeg_stream (ref, check, "v"); - check_ffmpeg_stream (ref, check, "a"); + int const r = system (string("ffcmp " + ref.string() + " " + check.string()).c_str()); + BOOST_REQUIRE_EQUAL (WEXITSTATUS(r), 0); } void