-#!/bin/bash -e
+#!/bin/bash
#
-# Run our test suite, which (amongst other things)
-# builds a couple of DCPs.
-# The outputs are compared against the ones
-# in test/ref/DCP, and an error is given
-# if anything is different.
+# Run our test suite.
-private=test/private
+# Private test data; this is stuff that is non-distributable
+private=../libdcp-test-private
+# Work directory
+work=build/test
+# Path to dcpinfo tool
+dcpinfo=build/tools/dcpinfo
+
+export LD_LIBRARY_PATH=build/src:/home/c.hetherington/lib:$LD_LIBRARY_PATH
+
+# Make sure we have the required tools
+for c in xmlsec1 xmldiff xmllint; do
+ hash $c 2>/dev/null || { echo >&2 "$c required but not found; aborting"; exit 1; }
+done
# Run the unit tests in test/
if [ "$1" == "--debug" ]; then
shift
- LD_LIBRARY_PATH=build/src:build/asdcplib/src gdb --args build/test/tests
+ gdb --args $work/tests $private $*
elif [ "$1" == "--valgrind" ]; then
shift
- LD_LIBRARY_PATH=build/src:build/asdcplib/src valgrind --tool="memcheck" build/test/tests
+ valgrind --tool="memcheck" $work/tests $private $*
+elif [ "$1" == "--callgrind" ]; then
+ shift
+ valgrind --tool="callgrind" $work/tests $private $*
else
- LD_LIBRARY_PATH=build/src:build/asdcplib/src build/test/tests $*
+ # This gives a warning from newer boost versions but doing it
+ # as $work/tests $* -- $private fails on older boost versions.
+ $work/tests $private $*
+ if [ "$?" != "0" ]; then
+ echo "FAIL: unit tests"
+ exit 1
+ fi
+fi
+
+# Check a MXF written by the unit tests
+diff $work/baz/video1.mxf $work/baz/video2.mxf
+if [ "$?" != "0" ]; then
+ echo "FAIL: MXFs from recovery incorrect"
+ exit 1
fi
-if [ ! -e "test/private/info.log" ]; then
- echo "Private data not found: some tests will not run"
+# Check the DCP written by dcp_test1
+diff -ur test/ref/DCP/dcp_test1 $work/DCP/dcp_test1
+if [ "$?" != "0" ]; then
+ echo "FAIL: files differ"
+ exit 1
fi
-# Check the first DCP written by the unit tests
-diff -ur test/ref/DCP/foo build/test/DCP/foo
+# Check the DCP written by dcp_test2
+diff -ur test/ref/DCP/dcp_test2 $work/DCP/dcp_test2
if [ "$?" != "0" ]; then
echo "FAIL: files differ"
exit 1
fi
-# Check the second DCP written by the unit tests
-diff -ur test/ref/DCP/bar build/test/DCP/bar
+# Check the DCP written by dcp_test5
+diff -ur test/ref/DCP/dcp_test5 $work/DCP/dcp_test5
if [ "$?" != "0" ]; then
echo "FAIL: files differ"
exit 1
fi
-# Run dcpinfo on all the DCPs in private/metadata, writing build/test/info.log
-rm -f build/test/info.log
-for d in `find $private/metadata -mindepth 1 -maxdepth 1 -type d | sort`; do
+# Check the DCP written by dcp_test7
+diff -ur test/ref/DCP/dcp_test7 $work/DCP/dcp_test7
+if [ "$?" != "0" ]; then
+ echo "FAIL: files differ"
+ exit 1
+fi
+
+# Check the DCP written by encryption_test
+diff -ur test/ref/DCP/encryption_test $work/DCP/encryption_test
+if [ "$?" != "0" ]; then
+ echo "FAIL: files differ"
+ exit 1
+fi
+
+# Everything beyond this point needs $private to exist
+if [ ! -e "$private/info.log" ]; then
+ echo ""
+ echo "Private data not found: some tests will not run."
+ exit 1
+fi
+
+# Run dcpinfo on all the DCPs in private/metadata, writing $work/info.log
+# This writes details of the CPLs and all subtitle details, so it checks
+# if the code is reading subtitle files correctly.
+rm -f $work/info.log
+for d in `find $private/metadata -mindepth 1 -maxdepth 1 -type d | sort -f -d`; do
if [ `basename $d` != ".git" ]; then
- LD_LIBRARY_PATH=build/src:build/asdcplib/src build/tools/dcpinfo -s $d >> build/test/info.log
+ $dcpinfo --ignore-missing-assets -s $d >> $work/info.log
if [ "$?" != "0" ]; then
echo "FAIL: dcpinfo failed for $d"
exit 1
done
# Check info.log is what it should be
-diff -q build/test/info.log $private/info.log
+diff -q $work/info.log $private/info.log
if [ "$?" != "0" ]; then
echo "FAIL: dcpinfo output incorrect"
exit 1
fi
-# Copy test/private into build/ then re-write the subtitles of every DCP using
-# build/test/rewrite_subs. This tests round-trip of subtitle reading/writing.
-rm -f build/test/info2.log
-rm -rf build/test/private
-cp -r $private build/test
-for d in `find build/test/private/metadata -mindepth 1 -maxdepth 1 -type d | sort`; do
+# Copy $private into build/ then re-write the subtitles of every DCP using
+# $work/rewrite_subs. This tests round-trip of subtitle reading/writing.
+# Note that all the subs in $private/metadata are Interop.
+rm -f $work/info2.log
+rm -rf $work/private
+mkdir $work/private
+cp -r $private/* $work/private
+for d in `find $work/private/metadata -mindepth 1 -maxdepth 1 -type d | sort -f -d`; do
if [ `basename $d` != ".git" ]; then
- LD_LIBRARY_PATH=build/src:build/asdcplib/src build/test/rewrite_subs $d
- LD_LIBRARY_PATH=build/src:build/asdcplib/src build/tools/dcpinfo -s $d >> build/test/info2.log
+ $work/rewrite_subs $d
+ $dcpinfo --ignore-missing-assets -s $d >> $work/info2.log
fi
done
# Fudge the output
-sed -i "s/DCP: build\/test/DCP: test/g" build/test/info2.log
+sed -i "s/DCP: build\/test/DCP: test/g" $work/info2.log
# And check it
-diff -q build/test/info2.log $private/info.log
+diff -q $work/info2.log $private/info2.log
if [ "$?" != "0" ]; then
echo "FAIL: dcpinfo output from rewrite incorrect"
exit 1
fi
-# Check a MXF written by the unit tests
-diff build/test/baz/video1.mxf build/test/baz/video2.mxf
+# Dump the subs of JourneyToJah... (which has MXF-wrapped SMPTE subtitles)
+# and check that they are right
+$dcpinfo -s $private/data/JourneyToJah_TLR-1_F_EN-DE-FR_CH_51_2K_LOK_20140225_DGL_SMPTE_OV >> $work/jah.log
+
+# Parse some problematic subs and check that we get it right
+run/test/subs_in_out $private/TunaBoat_Icelandic_Reel1_V1_8sec.xml > $work/tuna.xml
+diff -q $private/TunaBoat_Icelandic_Reel1_V1_8sec.parsed.xml $work/tuna.xml
if [ "$?" != "0" ]; then
- echo "FAIL: MXFs from recovery incorrect"
+ echo "FAIL: output of parse check 1 invalid"
exit 1
fi
-
+
echo "PASS"