#include "lib/encode_server_finder.h"
#include "lib/image.h"
#include "lib/ratio.h"
+#include "lib/dcp_content_type.h"
#include "lib/log_entry.h"
#include <dcp/dcp.h>
+#include <dcp/cpl.h>
+#include <dcp/reel.h>
+#include <dcp/reel_picture_asset.h>
+#include <dcp/mono_picture_frame.h>
+#include <dcp/mono_picture_asset.h>
+#include <dcp/openjpeg_image.h>
#include <asdcp/AS_DCP.h>
#include <sndfile.h>
#include <libxml++/libxml++.h>
#define BOOST_TEST_DYN_LINK
#define BOOST_TEST_MODULE dcpomatic_test
#include <boost/test/unit_test.hpp>
+#include <boost/algorithm/string.hpp>
#include <list>
#include <vector>
#include <iostream>
using std::abs;
using boost::shared_ptr;
using boost::scoped_array;
+using boost::dynamic_pointer_cast;
boost::filesystem::path private_data = boost::filesystem::path ("..") / boost::filesystem::path ("dcpomatic-test-private");
Config::instance()->set_default_interop (false);
Config::instance()->set_default_still_length (10);
Config::instance()->set_log_types (LogEntry::TYPE_GENERAL | LogEntry::TYPE_WARNING | LogEntry::TYPE_ERROR);
+ Config::instance()->set_automatic_audio_analysis (false);
EncodeServerFinder::instance()->stop ();
signal_manager = new TestSignalManager ();
+
+ char* env_private = getenv("DCPOMATIC_TEST_PRIVATE");
+ if (env_private) {
+ private_data = env_private;
+ }
}
~TestConfig ()
return film;
}
+shared_ptr<Film>
+new_test_film2 (string name)
+{
+ boost::filesystem::path p = test_film_dir (name);
+ if (boost::filesystem::exists (p)) {
+ boost::filesystem::remove_all (p);
+ }
+
+ shared_ptr<Film> film = shared_ptr<Film> (new Film (p));
+ film->set_dcp_content_type (DCPContentType::from_isdcf_name ("TST"));
+ film->set_container (Ratio::from_id ("185"));
+ film->write_metadata ();
+ return film;
+}
+
void
check_wav_file (boost::filesystem::path ref, boost::filesystem::path check)
{
m.write (file.string ());
}
-class Reader
+static
+void
+check_ffmpeg_stream (boost::filesystem::path ref, boost::filesystem::path check, string stream)
{
-public:
- Reader (boost::filesystem::path file)
- {
- format_context = avformat_alloc_context ();
- BOOST_REQUIRE (format_context);
- BOOST_REQUIRE (avformat_open_input (&format_context, file.string().c_str(), 0, 0) >= 0);
- BOOST_REQUIRE (avformat_find_stream_info (format_context, 0) >= 0);
- }
-
- ~Reader ()
- {
- avformat_close_input (&format_context);
- }
-
- AVFormatContext* format_context;
-};
-
+ 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, int skip_packet_stream)
{
- Reader ref_r (ref);
- Reader check_r (check);
+ check_ffmpeg_stream (ref, check, "v");
+ check_ffmpeg_stream (ref, check, "a");
+}
+
+void
+check_one_frame (boost::filesystem::path dcp_dir, int64_t index, boost::filesystem::path ref)
+{
+ dcp::DCP dcp (dcp_dir);
+ dcp.read ();
+ shared_ptr<dcp::MonoPictureAsset> asset = dynamic_pointer_cast<dcp::MonoPictureAsset> (dcp.cpls().front()->reels().front()->main_picture()->asset());
+ BOOST_REQUIRE (asset);
+ shared_ptr<const dcp::MonoPictureFrame> frame = asset->start_read()->get_frame(index);
- BOOST_REQUIRE_EQUAL (ref_r.format_context->nb_streams, check_r.format_context->nb_streams);
+ boost::uintmax_t const ref_size = boost::filesystem::file_size(ref);
+ BOOST_CHECK_EQUAL (frame->j2k_size(), ref_size);
- AVPacket ref_p;
- AVPacket check_p;
+ FILE* ref_file = fopen_boost(ref, "rb");
+ BOOST_REQUIRE (ref_file);
- bool skipped = false;
+ uint8_t* ref_data = new uint8_t[ref_size];
+ fread (ref_data, ref_size, 1, ref_file);
+ fclose (ref_file);
- while (true) {
- int p = av_read_frame (ref_r.format_context, &ref_p);
- int q = av_read_frame (check_r.format_context, &check_p);
- if (ref_p.stream_index == skip_packet_stream && check_p.stream_index == skip_packet_stream && !skipped) {
- skipped = true;
- continue;
- }
- BOOST_REQUIRE_EQUAL (p, q);
- BOOST_REQUIRE (p == 0 || p == AVERROR_EOF);
- if (p == AVERROR_EOF) {
- break;
- }
+ BOOST_CHECK (memcmp(ref_data, frame->j2k_data(), ref_size) == 0);
+ delete[] ref_data;
+}
- BOOST_REQUIRE_EQUAL (ref_p.buf->size, check_p.buf->size);
- BOOST_REQUIRE_EQUAL (memcmp (ref_p.buf->data, check_p.buf->data, ref_p.buf->size), 0);
+boost::filesystem::path
+dcp_file (shared_ptr<const Film> film, string prefix)
+{
+ boost::filesystem::directory_iterator i = boost::filesystem::directory_iterator (film->dir(film->dcp_name()));
+ while (i != boost::filesystem::directory_iterator() && !boost::algorithm::starts_with (i->path().leaf().string(), prefix)) {
+ ++i;
}
+
+ BOOST_REQUIRE (i != boost::filesystem::directory_iterator());
+ return i->path();
}