metaflac: add --scan-replay-gain option
[flac.git] / test / test_grabbag.sh
1 #!/bin/sh -e
2
3 #  FLAC - Free Lossless Audio Codec
4 #  Copyright (C) 2001-2009  Josh Coalson
5 #  Copyright (C) 2011-2014  Xiph.Org Foundation
6 #
7 #  This file is part the FLAC project.  FLAC is comprised of several
8 #  components distributed under different licenses.  The codec libraries
9 #  are distributed under Xiph.Org's BSD-like license (see the file
10 #  COPYING.Xiph in this distribution).  All other programs, libraries, and
11 #  plugins are distributed under the GPL (see COPYING.GPL).  The documentation
12 #  is distributed under the Gnu FDL (see COPYING.FDL).  Each file in the
13 #  FLAC distribution contains at the top the terms under which it may be
14 #  distributed.
15 #
16 #  Since this particular file is relevant to all components of FLAC,
17 #  it may be distributed under the Xiph.Org license, which is the least
18 #  restrictive of those mentioned above.  See the file COPYING.Xiph in this
19 #  distribution.
20
21 . ./common.sh
22
23 PATH=../src/test_grabbag/cuesheet:$PATH
24 PATH=../src/test_grabbag/picture:$PATH
25 PATH=../objs/$BUILD/bin:$PATH
26
27 test_cuesheet -h 1>/dev/null 2>/dev/null || die "ERROR can't find test_cuesheet executable"
28 test_picture -h 1>/dev/null 2>/dev/null || die "ERROR can't find test_picture executable"
29
30 run_test_cuesheet ()
31 {
32         if [ x"$FLAC__TEST_WITH_VALGRIND" = xyes ] ; then
33                 echo "valgrind --leak-check=yes --show-reachable=yes --num-callers=50 test_cuesheet $*" >>test_grabbag.valgrind.log
34                 valgrind --leak-check=yes --show-reachable=yes --num-callers=50 --log-fd=4 test_cuesheet${EXE} $* 4>>test_grabbag.valgrind.log
35         else
36                 test_cuesheet${EXE} $*
37         fi
38 }
39
40 run_test_picture ()
41 {
42         if [ x"$FLAC__TEST_WITH_VALGRIND" = xyes ] ; then
43                 echo "valgrind --leak-check=yes --show-reachable=yes --num-callers=50 test_picture $*" >>test_grabbag.valgrind.log
44                 valgrind --leak-check=yes --show-reachable=yes --num-callers=50 --log-fd=4 test_picture${EXE} $* 4>>test_grabbag.valgrind.log
45         else
46                 test_picture${EXE} $*
47         fi
48 }
49
50 if [ `env | grep -ic '^comspec='` != 0 ] ; then
51         is_win=yes
52 else
53         is_win=no
54 fi
55
56 ########################################################################
57 #
58 # test_picture
59 #
60 ########################################################################
61
62 log=picture.log
63 picture_dir=${top_srcdir}/test/pictures
64
65 echo "Running test_picture..."
66
67 rm -f $log
68
69 run_test_picture $picture_dir >> $log 2>&1
70
71 if [ $is_win = yes ] ; then
72         diff -w ${top_srcdir}/test/picture.ok $log > picture.diff || die "Error: .log file does not match .ok file, see picture.diff"
73 else
74         diff ${top_srcdir}/test/picture.ok $log > picture.diff || die "Error: .log file does not match .ok file, see picture.diff"
75 fi
76
77 echo "PASSED (results are in $log)"
78
79 ########################################################################
80 #
81 # test_cuesheet
82 #
83 ########################################################################
84
85 log=cuesheet.log
86 bad_cuesheets=${top_srcdir}/test/cuesheets/bad.*.cue
87 good_cuesheets=${top_srcdir}/test/cuesheets/good.*.cue
88 good_leadout=`expr 80 \* 60 \* 44100`
89 bad_leadout=`expr $good_leadout + 1`
90
91 echo "Running test_cuesheet..."
92
93 rm -f $log
94
95 #
96 # negative tests
97 #
98 for cuesheet in $bad_cuesheets ; do
99         echo "NEGATIVE $cuesheet" | sed "s|${top_srcdir}/test/||" >> $log 2>&1
100         run_test_cuesheet $cuesheet $good_leadout 44100 cdda >> $log 2>&1 || exit_code=$?
101         if [ "$exit_code" = 255 ] ; then
102                 die "Error: test script is broken"
103         fi
104         cuesheet_pass1=${cuesheet}.1
105         cuesheet_pass2=${cuesheet}.2
106         rm -f $cuesheet_pass1 $cuesheet_pass2
107 done
108
109 #
110 # positve tests
111 #
112 for cuesheet in $good_cuesheets ; do
113         echo "POSITIVE $cuesheet" | sed "s|${top_srcdir}/test/||" >> $log 2>&1
114         run_test_cuesheet $cuesheet $good_leadout 44100 cdda >> $log 2>&1
115         exit_code=$?
116         if [ "$exit_code" = 255 ] ; then
117                 die "Error: test script is broken"
118         elif [ "$exit_code" != 0 ] ; then
119                 die "Error: good cuesheet is broken"
120         fi
121         cuesheet_out=$(echo $cuesheet | sed "s|${top_srcdir}/test/||")
122         cuesheet_pass1=${cuesheet_out}.1
123         cuesheet_pass2=${cuesheet_out}.2
124         diff $cuesheet_pass1 $cuesheet_pass2 >> $log 2>&1 || die "Error: pass1 and pass2 output differ"
125         rm -f $cuesheet_pass1 $cuesheet_pass2
126 done
127
128 if [ $is_win = yes ] ; then
129         diff -w ${top_srcdir}/test/cuesheet.ok $log > cuesheet.diff || die "Error: .log file does not match .ok file, see cuesheet.diff"
130 else
131         diff ${top_srcdir}/test/cuesheet.ok $log > cuesheet.diff || die "Error: .log file does not match .ok file, see cuesheet.diff"
132 fi
133
134 echo "PASSED (results are in $log)"