summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2015-10-13 11:30:30 +0100
committerCarl Hetherington <cth@carlh.net>2015-10-13 11:30:30 +0100
commit6f23b55a7783f93549115a133ca2e6e938bd0cd1 (patch)
tree6c674d088eb37dd9d91992366cfa6ddb3e0e69e5 /test
parentf9068dcbfbb09082e29e2a779ef1a7a2f6ee849e (diff)
Some attempts to block referencing of DCPs when it is not possible.
Diffstat (limited to 'test')
-rw-r--r--test/fft.py17
-rw-r--r--test/reels_test.cc141
-rw-r--r--test/vf_test.cc66
-rw-r--r--test/wscript1
4 files changed, 225 insertions, 0 deletions
diff --git a/test/fft.py b/test/fft.py
new file mode 100644
index 000000000..bc6509f6c
--- /dev/null
+++ b/test/fft.py
@@ -0,0 +1,17 @@
+#!/usr/bin/python
+
+from pylab import *
+import numpy
+
+f = open('build/test/lpf_ir')
+ir = []
+while True:
+ l = f.readline()
+ if l == "":
+ break
+
+ ir.append(float(l.strip()))
+
+#plot(abs(numpy.fft.fft(ir)))
+plot(ir)
+show()
diff --git a/test/reels_test.cc b/test/reels_test.cc
new file mode 100644
index 000000000..85a9d07a9
--- /dev/null
+++ b/test/reels_test.cc
@@ -0,0 +1,141 @@
+/*
+ Copyright (C) 2015 Carl Hetherington <cth@carlh.net>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
+#include "lib/film.h"
+#include "lib/ratio.h"
+#include "lib/ffmpeg_content.h"
+#include "lib/image_content.h"
+#include "lib/dcp_content_type.h"
+#include "lib/dcp_content.h"
+#include "test.h"
+#include <boost/test/unit_test.hpp>
+
+using std::list;
+using boost::shared_ptr;
+
+/** Test Film::reels() */
+BOOST_AUTO_TEST_CASE (reels_test1)
+{
+ shared_ptr<Film> film = new_test_film ("reels_test1");
+ film->set_container (Ratio::from_id ("185"));
+ shared_ptr<FFmpegContent> A (new FFmpegContent (film, "test/data/test.mp4"));
+ film->examine_and_add_content (A);
+ shared_ptr<FFmpegContent> B (new FFmpegContent (film, "test/data/test.mp4"));
+ film->examine_and_add_content (B);
+ wait_for_jobs ();
+ BOOST_CHECK_EQUAL (A->full_length(), DCPTime (288000));
+
+ film->set_reel_type (REELTYPE_SINGLE);
+ list<DCPTimePeriod> r = film->reels ();
+ BOOST_CHECK_EQUAL (r.size(), 1);
+ BOOST_CHECK_EQUAL (r.front().from, DCPTime (0));
+ BOOST_CHECK_EQUAL (r.front().to, DCPTime (288000 * 2));
+
+ film->set_reel_type (REELTYPE_BY_VIDEO_CONTENT);
+ r = film->reels ();
+ BOOST_CHECK_EQUAL (r.size(), 2);
+ BOOST_CHECK_EQUAL (r.front().from, DCPTime (0));
+ BOOST_CHECK_EQUAL (r.front().to, DCPTime (288000));
+ BOOST_CHECK_EQUAL (r.back().from, DCPTime (288000));
+ BOOST_CHECK_EQUAL (r.back().to, DCPTime (288000 * 2));
+
+ film->set_j2k_bandwidth (100000000);
+ film->set_reel_type (REELTYPE_BY_LENGTH);
+ /* This is just over 2.5s at 100Mbit/s; should correspond to 60 frames */
+ film->set_reel_length (31253154);
+ r = film->reels ();
+ BOOST_CHECK_EQUAL (r.size(), 3);
+ list<DCPTimePeriod>::const_iterator i = r.begin ();
+ BOOST_CHECK_EQUAL (i->from, DCPTime (0));
+ BOOST_CHECK_EQUAL (i->to, DCPTime::from_frames (60, 24));
+ ++i;
+ BOOST_CHECK_EQUAL (i->from, DCPTime::from_frames (60, 24));
+ BOOST_CHECK_EQUAL (i->to, DCPTime::from_frames (120, 24));
+ ++i;
+ BOOST_CHECK_EQUAL (i->from, DCPTime::from_frames (120, 24));
+ BOOST_CHECK_EQUAL (i->to, DCPTime::from_frames (144, 24));
+}
+
+/** Make a short DCP with multi reels split by video content, then import
+ * this into a new project and make a new DCP referencing it.
+ */
+BOOST_AUTO_TEST_CASE (reels_test2)
+{
+ shared_ptr<Film> film = new_test_film ("reels_test2");
+ film->set_name ("reels_test2");
+ film->set_container (Ratio::from_id ("185"));
+ film->set_dcp_content_type (DCPContentType::from_pretty_name ("Test"));
+
+ {
+ shared_ptr<ImageContent> c (new ImageContent (film, "test/data/flat_red.png"));
+ film->examine_and_add_content (c);
+ wait_for_jobs ();
+ c->set_video_length (24);
+ }
+
+ {
+ shared_ptr<ImageContent> c (new ImageContent (film, "test/data/flat_green.png"));
+ film->examine_and_add_content (c);
+ wait_for_jobs ();
+ c->set_video_length (24);
+ }
+
+ {
+ shared_ptr<ImageContent> c (new ImageContent (film, "test/data/flat_blue.png"));
+ film->examine_and_add_content (c);
+ wait_for_jobs ();
+ c->set_video_length (24);
+ }
+
+ film->set_reel_type (REELTYPE_BY_VIDEO_CONTENT);
+ wait_for_jobs ();
+
+ film->make_dcp ();
+ wait_for_jobs ();
+
+ check_dcp ("test/data/reels_test2", film->dir (film->dcp_name()));
+
+ shared_ptr<Film> film2 = new_test_film ("reels_test3");
+ film2->set_name ("reels_test3");
+ film2->set_container (Ratio::from_id ("185"));
+ film2->set_dcp_content_type (DCPContentType::from_pretty_name ("Test"));
+ film2->set_reel_type (REELTYPE_BY_VIDEO_CONTENT);
+
+ shared_ptr<DCPContent> c (new DCPContent (film2, film->dir (film->dcp_name ())));
+ film2->examine_and_add_content (c);
+ wait_for_jobs ();
+
+ list<DCPTimePeriod> r = film2->reels ();
+ BOOST_CHECK_EQUAL (r.size(), 3);
+ list<DCPTimePeriod>::const_iterator i = r.begin ();
+ BOOST_CHECK_EQUAL (i->from, DCPTime (0));
+ BOOST_CHECK_EQUAL (i->to, DCPTime (96000));
+ ++i;
+ BOOST_CHECK_EQUAL (i->from, DCPTime (96000));
+ BOOST_CHECK_EQUAL (i->to, DCPTime (96000 * 2));
+ ++i;
+ BOOST_CHECK_EQUAL (i->from, DCPTime (96000 * 2));
+ BOOST_CHECK_EQUAL (i->to, DCPTime (96000 * 3));
+
+ c->set_reference_video (true);
+ c->set_reference_audio (true);
+
+ film2->make_dcp ();
+ wait_for_jobs ();
+}
diff --git a/test/vf_test.cc b/test/vf_test.cc
new file mode 100644
index 000000000..904f1d559
--- /dev/null
+++ b/test/vf_test.cc
@@ -0,0 +1,66 @@
+/*
+ Copyright (C) 2015 Carl Hetherington <cth@carlh.net>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
+#include "lib/film.h"
+#include "lib/dcp_content.h"
+#include "lib/ffmpeg_content.h"
+#include "test.h"
+#include <boost/test/unit_test.hpp>
+
+using std::list;
+using std::string;
+using boost::shared_ptr;
+
+/** Test the logic which decides whether a DCP can be referenced or not */
+BOOST_AUTO_TEST_CASE (vf_test1)
+{
+ shared_ptr<Film> film = new_test_film ("vf_test1");
+ shared_ptr<DCPContent> dcp (new DCPContent (film, "test/data/reels_test2"));
+ film->examine_and_add_content (dcp);
+ wait_for_jobs ();
+
+ /* Multi-reel DCP can't be referenced if we are using a single reel for the project */
+ film->set_reel_type (REELTYPE_SINGLE);
+ list<string> why_not;
+ BOOST_CHECK (!dcp->can_reference_video(why_not));
+ BOOST_CHECK (!dcp->can_reference_audio(why_not));
+ BOOST_CHECK (!dcp->can_reference_subtitle(why_not));
+
+ /* Multi-reel DCP can be referenced if we are using by-video-content */
+ film->set_reel_type (REELTYPE_BY_VIDEO_CONTENT);
+ BOOST_CHECK (dcp->can_reference_video(why_not));
+ BOOST_CHECK (dcp->can_reference_audio(why_not));
+ BOOST_CHECK (dcp->can_reference_subtitle(why_not));
+
+ shared_ptr<FFmpegContent> other (new FFmpegContent (film, "test/data/test.mp4"));
+ film->examine_and_add_content (other);
+ wait_for_jobs ();
+
+ /* Not possible if there is overlap */
+ other->set_position (DCPTime (0));
+ BOOST_CHECK (!dcp->can_reference_video(why_not));
+ BOOST_CHECK (!dcp->can_reference_audio(why_not));
+ BOOST_CHECK (!dcp->can_reference_subtitle(why_not));
+
+ /* This should not be considered an overlap */
+ other->set_position (dcp->end ());
+ BOOST_CHECK (dcp->can_reference_video(why_not));
+ BOOST_CHECK (dcp->can_reference_audio(why_not));
+ BOOST_CHECK (dcp->can_reference_subtitle(why_not));
+}
diff --git a/test/wscript b/test/wscript
index 89f84e836..5cbc327e1 100644
--- a/test/wscript
+++ b/test/wscript
@@ -85,6 +85,7 @@ def build(bld):
update_checker_test.cc
upmixer_a_test.cc
util_test.cc
+ vf_test.cc
video_content_scale_test.cc
video_decoder_fill_test.cc
xml_subtitle_test.cc