X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=run-tests.sh;h=9456273a9c93c5ea2e2c408e486068091aa5baac;hb=56295f9d82c74b967b234ac89a5600d5cff1b641;hp=c75c8c2ad97a0515468025d1881d4fd6d9e1bd43;hpb=8f6f5c5c8f09d8aa880c3f2f29530744576212a1;p=libdcp.git diff --git a/run-tests.sh b/run-tests.sh index c75c8c2a..9456273a 100755 --- a/run-tests.sh +++ b/run-tests.sh @@ -1,36 +1,81 @@ -#!/bin/bash +#!/bin/bash -e # -# Runs our test suite, which builds a DCP. -# The output is compared against the one +# Runs 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. # +if [ ! -e "../libdcp-test" ]; then + echo "Test corpus not found" + exit 1 +fi + if [ "$1" == "--debug" ]; then shift LD_LIBRARY_PATH=build/src:build/asdcplib/src gdb --args build/test/tests +elif [ "$1" == "--valgrind" ]; then + shift + LD_LIBRARY_PATH=build/src:build/asdcplib/src valgrind --tool="memcheck" build/test/tests else LD_LIBRARY_PATH=build/src:build/asdcplib/src build/test/tests fi -diff -ur test/ref/DCP build/test/foo + +diff -ur test/ref/DCP/foo build/test/foo +if [ "$?" != "0" ]; then + echo "FAIL: files differ" + exit 1 +fi + +diff -ur test/ref/DCP/bar build/test/bar if [ "$?" != "0" ]; then echo "FAIL: files differ" exit 1 fi -if [ -e "../libdcp-test" ]; then - for d in `find ../libdcp-test -mindepth 1 -maxdepth 1 -type d`; do - LD_LIBRARY_PATH=build/src:build/asdcplib/src build/tools/dcpinfo $d +rm -f build/test/info.log + +for d in `find ../libdcp-test -mindepth 1 -maxdepth 1 -type d | sort`; do + if [ `basename $d` != ".git" ]; then + LD_LIBRARY_PATH=build/src:build/asdcplib/src build/tools/dcpinfo -s $d >> build/test/info.log if [ "$?" != "0" ]; then - echo "FAIL: dcpinfo failed" + echo "FAIL: dcpinfo failed for $d" exit 1 fi - done -else - echo "Test corpus not found" + fi +done + +diff -q build/test/info.log ../libdcp-test/info.log +if [ "$?" != "0" ]; then + echo "FAIL: dcpinfo output incorrect" exit 1 fi -echo "PASS" +rm -f build/test/info2.log +rm -rf build/test/libdcp-test + +cp -r ../libdcp-test build/test +for d in `find build/test/libdcp-test -mindepth 1 -maxdepth 1 -type d | sort`; 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 + fi +done +sed -i "s/DCP: build\/test/DCP: \.\./g" build/test/info2.log + +diff -q build/test/info2.log ../libdcp-test/info.log +if [ "$?" != "0" ]; then + echo "FAIL: dcpinfo output from rewrite incorrect" + exit 1 +fi + +diff build/test/baz/video1.mxf build/test/baz/video2.mxf +if [ "$?" != "0" ]; then + echo "FAIL: MXFs from recovery incorrect" + exit 1 +fi + +echo "PASS"