blob: 8cd7b4eae66f4e1f321c3c1b865f9bb1f1e7029b [file] [log] [blame]
Josh Coalson463d0f82002-12-10 06:41:27 +00001#!/bin/sh
2
3# FLAC - Free Lossless Audio Codec
Josh Coalson95643902004-01-17 04:14:43 +00004# Copyright (C) 2001,2002,2003,2004 Josh Coalson
Josh Coalson463d0f82002-12-10 06:41:27 +00005#
Josh Coalsone8a76012003-02-07 00:14:32 +00006# This file is part the FLAC project. FLAC is comprised of several
7# components distributed under difference licenses. The codec libraries
8# are distributed under Xiph.Org's BSD-like license (see the file
9# COPYING.Xiph in this distribution). All other programs, libraries, and
10# plugins are distributed under the GPL (see COPYING.GPL). The documentation
11# is distributed under the Gnu FDL (see COPYING.FDL). Each file in the
12# FLAC distribution contains at the top the terms under which it may be
13# distributed.
Josh Coalson463d0f82002-12-10 06:41:27 +000014#
Josh Coalsone8a76012003-02-07 00:14:32 +000015# Since this particular file is relevant to all components of FLAC,
16# it may be distributed under the Xiph.Org license, which is the least
17# restrictive of those mentioned above. See the file COPYING.Xiph in this
18# distribution.
Josh Coalson463d0f82002-12-10 06:41:27 +000019
Josh Coalson8fac5d62002-12-12 03:57:47 +000020die ()
21{
22 echo $* 1>&2
23 exit 1
24}
25
Josh Coalson463d0f82002-12-10 06:41:27 +000026LD_LIBRARY_PATH=../src/libFLAC/.libs:../obj/release/lib:../obj/debug/lib:$LD_LIBRARY_PATH
27export LD_LIBRARY_PATH
28PATH=../src/flac:../src/test_streams:../obj/release/bin:../obj/debug/bin:$PATH
29
Josh Coalson8fac5d62002-12-12 03:57:47 +000030flac --help 1>/dev/null 2>/dev/null || die "ERROR can't find flac executable"
Josh Coalson463d0f82002-12-10 06:41:27 +000031
32run_flac ()
33{
Josh Coalsonecf57b72003-01-14 09:00:25 +000034 if [ x"$FLAC__VALGRIND" = xyes ] ; then
Josh Coalson80936c52002-12-30 23:31:47 +000035 valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --logfile-fd=4 flac $* 4>>test_flac.valgrind.log
Josh Coalson463d0f82002-12-10 06:41:27 +000036 else
37 flac $*
38 fi
39}
40
41echo "Checking for --ogg support in flac..."
42if flac --ogg --silent --force-raw-format --endian=little --sign=signed --channels=1 --bps=8 --sample-rate=44100 -c $0 1>/dev/null 2>&1 ; then
43 has_ogg=yes;
44 echo "flac --ogg works"
45else
46 has_ogg=no;
47 echo "flac --ogg doesn't work"
48fi
49
Josh Coalson5126bb02002-12-17 08:15:48 +000050
51echo "Generating streams..."
52if [ ! -f wacky1.wav ] ; then
53 test_streams || die "ERROR during test_streams"
54fi
55
56############################################################################
Josh Coalson0bb57d02004-07-16 00:50:42 +000057# test that flac doesn't automatically overwrite files unless -f is used
58############################################################################
59
60echo "Try encoding to a file that exists; should fail"
61cp wacky1.wav exist.wav
62touch exist.flac
Josh Coalsone4240db2004-07-17 18:14:45 +000063if run_flac --totally-silent -0 exist.wav ; then
Josh Coalson0bb57d02004-07-16 00:50:42 +000064 die "ERROR: it should have failed but didn't"
65else
66 echo "OK, it failed as it should"
67fi
68
69echo "Try encoding with -f to a file that exists; should succeed"
Josh Coalsone4240db2004-07-17 18:14:45 +000070if run_flac --totally-silent -0 --force exist.wav ; then
Josh Coalson0bb57d02004-07-16 00:50:42 +000071 echo "OK, it succeeded as it should"
72else
73 die "ERROR: it should have succeeded but didn't"
74fi
75
76echo "Try decoding to a file that exists; should fail"
Josh Coalsone4240db2004-07-17 18:14:45 +000077if run_flac --totally-silent -d exist.flac ; then
Josh Coalson0bb57d02004-07-16 00:50:42 +000078 die "ERROR: it should have failed but didn't"
79else
80 echo "OK, it failed as it should"
81fi
82
83echo "Try decoding with -f to a file that exists; should succeed"
Josh Coalsone4240db2004-07-17 18:14:45 +000084if run_flac --totally-silent -d -f exist.flac ; then
Josh Coalson0bb57d02004-07-16 00:50:42 +000085 echo "OK, it succeeded as it should"
86else
87 die "ERROR: it should have succeeded but didn't"
88fi
89
90rm -f exist.wav exist.flac
91
92############################################################################
Josh Coalson5126bb02002-12-17 08:15:48 +000093# basic 'round-trip' tests of various kinds of streams
94############################################################################
95
96rt_test_raw ()
97{
98 f="$1"
99 channels=`echo $f | awk -F- '{print $2}'`
100 bytes_per_sample=`echo $f | awk -F- '{print $3}'`
101 bps=`expr $bytes_per_sample '*' 8`
102 echo -n "round-trip test ($f) encode... "
Josh Coalson0bb57d02004-07-16 00:50:42 +0000103 run_flac --silent --force --verify --force-raw-format --endian=little --sign=signed --sample-rate=44100 --bps=$bps --channels=$channels $f -o rt.flac || die "ERROR"
Josh Coalson5126bb02002-12-17 08:15:48 +0000104 echo -n "decode... "
Josh Coalson0bb57d02004-07-16 00:50:42 +0000105 run_flac --silent --force --decode --force-raw-format --endian=little --sign=signed -o rt.raw rt.flac || die "ERROR"
Josh Coalson5126bb02002-12-17 08:15:48 +0000106 echo -n "compare... "
107 cmp $f rt.raw || die "ERROR: file mismatch"
108 echo "OK"
109 rm -f rt.flac rt.raw
110}
111
112rt_test_wav ()
113{
114 f="$1"
115 echo -n "round-trip test ($f) encode... "
Josh Coalson0bb57d02004-07-16 00:50:42 +0000116 run_flac --silent --force --verify $f -o rt.flac || die "ERROR"
Josh Coalson5126bb02002-12-17 08:15:48 +0000117 echo -n "decode... "
Josh Coalson0bb57d02004-07-16 00:50:42 +0000118 run_flac --silent --force --decode -o rt.wav rt.flac || die "ERROR"
Josh Coalson5126bb02002-12-17 08:15:48 +0000119 echo -n "compare... "
120 cmp $f rt.wav || die "ERROR: file mismatch"
121 echo "OK"
122 rm -f rt.flac rt.wav
123}
124
125rt_test_aiff ()
126{
127 f="$1"
128 echo -n "round-trip test ($f) encode... "
Josh Coalson0bb57d02004-07-16 00:50:42 +0000129 run_flac --silent --force --verify $f -o rt.flac || die "ERROR"
Josh Coalson5126bb02002-12-17 08:15:48 +0000130 echo -n "decode... "
Josh Coalson0bb57d02004-07-16 00:50:42 +0000131 run_flac --silent --force --decode -o rt.aiff rt.flac || die "ERROR"
Josh Coalson5126bb02002-12-17 08:15:48 +0000132 echo -n "compare... "
133 cmp $f rt.aiff || die "ERROR: file mismatch"
134 echo "OK"
135 rm -f rt.flac rt.aiff
136}
137
138for f in rt-*.raw ; do
139 rt_test_raw $f
140done
141for f in rt-*.wav ; do
142 rt_test_wav $f
143done
144for f in rt-*.aiff ; do
145 rt_test_aiff $f
146done
147
Josh Coalson8fac5d62002-12-12 03:57:47 +0000148############################################################################
149# test --skip and --until
150############################################################################
151
Josh Coalson463d0f82002-12-10 06:41:27 +0000152#
Josh Coalson8232e292002-12-14 06:22:22 +0000153# first make some chopped-up raw files
Josh Coalson463d0f82002-12-10 06:41:27 +0000154#
Josh Coalson8fac5d62002-12-12 03:57:47 +0000155echo "abcdefghijklmnopqrstuvwxyz1234567890ABCDEFGHIJKLMN" > master.raw
156dddie="die ERROR: creating files for --skip/--until tests"
157dd if=master.raw ibs=1 count=50 of=50c.raw 2>/dev/null || $dddie
158dd if=master.raw ibs=1 skip=10 count=40 of=50c.skip10.raw 2>/dev/null || $dddie
159dd if=master.raw ibs=1 skip=11 count=39 of=50c.skip11.raw 2>/dev/null || $dddie
Josh Coalson03a5a692004-07-17 00:23:17 +0000160dd if=master.raw ibs=1 skip=20 count=30 of=50c.skip20.raw 2>/dev/null || $dddie
161dd if=master.raw ibs=1 skip=30 count=20 of=50c.skip30.raw 2>/dev/null || $dddie
162dd if=master.raw ibs=1 skip=40 count=10 of=50c.skip40.raw 2>/dev/null || $dddie
163dd if=master.raw ibs=1 count=10 of=50c.until10.raw 2>/dev/null || $dddie
164dd if=master.raw ibs=1 count=20 of=50c.until20.raw 2>/dev/null || $dddie
165dd if=master.raw ibs=1 count=30 of=50c.until30.raw 2>/dev/null || $dddie
Josh Coalson8fac5d62002-12-12 03:57:47 +0000166dd if=master.raw ibs=1 count=39 of=50c.until39.raw 2>/dev/null || $dddie
Josh Coalson03a5a692004-07-17 00:23:17 +0000167dd if=master.raw ibs=1 count=40 of=50c.until40.raw 2>/dev/null || $dddie
168dd if=master.raw ibs=1 skip=10 count=20 of=50c.skip10.until30.raw 2>/dev/null || $dddie
Josh Coalson8fac5d62002-12-12 03:57:47 +0000169dd if=master.raw ibs=1 skip=10 count=29 of=50c.skip10.until39.raw 2>/dev/null || $dddie
Josh Coalson03a5a692004-07-17 00:23:17 +0000170dd if=master.raw ibs=1 skip=10 count=30 of=50c.skip10.until40.raw 2>/dev/null || $dddie
171dd if=master.raw ibs=1 skip=20 count=10 of=50c.skip20.until30.raw 2>/dev/null || $dddie
172dd if=master.raw ibs=1 skip=20 count=20 of=50c.skip20.until40.raw 2>/dev/null || $dddie
Josh Coalson463d0f82002-12-10 06:41:27 +0000173
Josh Coalson0bb57d02004-07-16 00:50:42 +0000174wav_eopt="--silent --force --verify --lax"
175wav_dopt="--silent --force --decode"
Josh Coalson8232e292002-12-14 06:22:22 +0000176
177raw_eopt="$wav_eopt --force-raw-format --endian=big --sign=signed --sample-rate=10 --bps=8 --channels=1"
178raw_dopt="$wav_dopt --force-raw-format --endian=big --sign=signed"
Josh Coalson8fac5d62002-12-12 03:57:47 +0000179
180#
Josh Coalson5126bb02002-12-17 08:15:48 +0000181# convert them to WAVE and AIFF files
Josh Coalson8fac5d62002-12-12 03:57:47 +0000182#
Josh Coalson8232e292002-12-14 06:22:22 +0000183convert_to_wav ()
184{
185 run_flac $raw_eopt $1.raw || die "ERROR converting $1.raw to WAVE"
186 run_flac $wav_dopt $1.flac || die "ERROR converting $1.raw to WAVE"
187}
188convert_to_wav 50c
189convert_to_wav 50c.skip10
190convert_to_wav 50c.skip11
Josh Coalson03a5a692004-07-17 00:23:17 +0000191convert_to_wav 50c.skip20
192convert_to_wav 50c.skip30
193convert_to_wav 50c.skip40
194convert_to_wav 50c.until10
195convert_to_wav 50c.until20
196convert_to_wav 50c.until30
Josh Coalson8232e292002-12-14 06:22:22 +0000197convert_to_wav 50c.until39
Josh Coalson03a5a692004-07-17 00:23:17 +0000198convert_to_wav 50c.until40
199convert_to_wav 50c.skip10.until30
Josh Coalson8232e292002-12-14 06:22:22 +0000200convert_to_wav 50c.skip10.until39
Josh Coalson03a5a692004-07-17 00:23:17 +0000201convert_to_wav 50c.skip10.until40
202convert_to_wav 50c.skip20.until30
203convert_to_wav 50c.skip20.until40
Josh Coalson8fac5d62002-12-12 03:57:47 +0000204
Josh Coalson5126bb02002-12-17 08:15:48 +0000205convert_to_aiff ()
206{
207 run_flac $raw_eopt $1.raw || die "ERROR converting $1.raw to AIFF"
208 run_flac $wav_dopt $1.flac -o $1.aiff || die "ERROR converting $1.raw to AIFF"
209}
210convert_to_aiff 50c
211convert_to_aiff 50c.skip10
212convert_to_aiff 50c.skip11
Josh Coalson03a5a692004-07-17 00:23:17 +0000213convert_to_aiff 50c.skip20
214convert_to_aiff 50c.skip30
215convert_to_aiff 50c.skip40
216convert_to_aiff 50c.until10
217convert_to_aiff 50c.until20
218convert_to_aiff 50c.until30
Josh Coalson5126bb02002-12-17 08:15:48 +0000219convert_to_aiff 50c.until39
Josh Coalson03a5a692004-07-17 00:23:17 +0000220convert_to_aiff 50c.until40
221convert_to_aiff 50c.skip10.until30
Josh Coalson5126bb02002-12-17 08:15:48 +0000222convert_to_aiff 50c.skip10.until39
Josh Coalson03a5a692004-07-17 00:23:17 +0000223convert_to_aiff 50c.skip10.until40
224convert_to_aiff 50c.skip20.until30
225convert_to_aiff 50c.skip20.until40
Josh Coalson5126bb02002-12-17 08:15:48 +0000226
Josh Coalson8232e292002-12-14 06:22:22 +0000227test_skip_until ()
228{
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000229 in_fmt=$1
230 out_fmt=$2
Josh Coalson463d0f82002-12-10 06:41:27 +0000231
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000232 [ "$in_fmt" = wav ] || [ "$in_fmt" = aiff ] || [ "$in_fmt" = raw ] || die "ERROR: internal error, bad 'in' format '$in_fmt'"
Josh Coalson463d0f82002-12-10 06:41:27 +0000233
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000234 [ "$out_fmt" = flac ] || [ "$out_fmt" = ogg ] || die "ERROR: internal error, bad 'out' format '$out_fmt'"
235
236 if [ $in_fmt = raw ] ; then
Josh Coalson8232e292002-12-14 06:22:22 +0000237 eopt="$raw_eopt"
238 dopt="$raw_dopt"
239 else
240 eopt="$wav_eopt"
241 dopt="$wav_dopt"
242 fi
Josh Coalson463d0f82002-12-10 06:41:27 +0000243
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000244 if [ $out_fmt = ogg ] ; then
245 eopt="--ogg $eopt"
246 fi
247
Josh Coalson8232e292002-12-14 06:22:22 +0000248 #
249 # test --skip when encoding
250 #
Josh Coalson8fac5d62002-12-12 03:57:47 +0000251
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000252 desc="($in_fmt<->$out_fmt)"
253
254 echo -n "testing --skip=# (encode) $desc... "
255 run_flac $eopt --skip=10 -o z50c.skip10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
256 run_flac $dopt -o z50c.skip10.$in_fmt z50c.skip10.$out_fmt || die "ERROR decoding FLAC file $desc"
257 cmp 50c.skip10.$in_fmt z50c.skip10.$in_fmt || die "ERROR: file mismatch for --skip=10 (encode) $desc"
258 rm -f z50c.skip10.$out_fmt z50c.skip10.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000259 echo OK
Josh Coalson463d0f82002-12-10 06:41:27 +0000260
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000261 echo -n "testing --skip=mm:ss (encode) $desc... "
262 run_flac $eopt --skip=0:01 -o z50c.skip0:01.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
263 run_flac $dopt -o z50c.skip0:01.$in_fmt z50c.skip0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
264 cmp 50c.skip10.$in_fmt z50c.skip0:01.$in_fmt || die "ERROR: file mismatch for --skip=0:01 (encode) $desc"
265 rm -f z50c.skip0:01.$out_fmt z50c.skip0:01.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000266 echo OK
Josh Coalson463d0f82002-12-10 06:41:27 +0000267
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000268 echo -n "testing --skip=mm:ss.sss (encode) $desc... "
269 run_flac $eopt --skip=0:01.1001 -o z50c.skip0:01.1001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
270 run_flac $dopt -o z50c.skip0:01.1001.$in_fmt z50c.skip0:01.1001.$out_fmt || die "ERROR decoding FLAC file $desc"
271 cmp 50c.skip11.$in_fmt z50c.skip0:01.1001.$in_fmt || die "ERROR: file mismatch for --skip=0:01.1001 (encode) $desc"
272 rm -f z50c.skip0:01.1001.$out_fmt z50c.skip0:01.1001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000273 echo OK
Josh Coalson463d0f82002-12-10 06:41:27 +0000274
Josh Coalson8232e292002-12-14 06:22:22 +0000275 #
276 # test --skip when decoding
277 #
Josh Coalson463d0f82002-12-10 06:41:27 +0000278
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000279 echo -n "testing --skip=# (decode) $desc... "
280 run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
281 run_flac $dopt --skip=10 -o z50c.skip10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
282 cmp 50c.skip10.$in_fmt z50c.skip10.$in_fmt || die "ERROR: file mismatch for --skip=10 (decode) $desc"
283 rm -f z50c.skip10.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000284 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000285
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000286 echo -n "testing --skip=mm:ss (decode) $desc... "
287 run_flac $dopt --skip=0:01 -o z50c.skip0:01.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
288 cmp 50c.skip10.$in_fmt z50c.skip0:01.$in_fmt || die "ERROR: file mismatch for --skip=0:01 (decode) $desc"
289 rm -f z50c.skip0:01.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000290 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000291
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000292 echo -n "testing --skip=mm:ss.sss (decode) $desc... "
293 run_flac $dopt --skip=0:01.1001 -o z50c.skip0:01.1001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
294 cmp 50c.skip11.$in_fmt z50c.skip0:01.1001.$in_fmt || die "ERROR: file mismatch for --skip=0:01.1001 (decode) $desc"
295 rm -f z50c.skip0:01.1001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000296 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000297
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000298 rm -f z50c.$out_fmt
Josh Coalson8fac5d62002-12-12 03:57:47 +0000299
Josh Coalson8232e292002-12-14 06:22:22 +0000300 #
301 # test --until when encoding
302 #
Josh Coalson8fac5d62002-12-12 03:57:47 +0000303
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000304 echo -n "testing --until=# (encode) $desc... "
305 run_flac $eopt --until=40 -o z50c.until40.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
306 run_flac $dopt -o z50c.until40.$in_fmt z50c.until40.$out_fmt || die "ERROR decoding FLAC file $desc"
307 cmp 50c.until40.$in_fmt z50c.until40.$in_fmt || die "ERROR: file mismatch for --until=40 (encode) $desc"
308 rm -f z50c.until40.$out_fmt z50c.until40.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000309 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000310
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000311 echo -n "testing --until=mm:ss (encode) $desc... "
312 run_flac $eopt --until=0:04 -o z50c.until0:04.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
313 run_flac $dopt -o z50c.until0:04.$in_fmt z50c.until0:04.$out_fmt || die "ERROR decoding FLAC file $desc"
314 cmp 50c.until40.$in_fmt z50c.until0:04.$in_fmt || die "ERROR: file mismatch for --until=0:04 (encode) $desc"
315 rm -f z50c.until0:04.$out_fmt z50c.until0:04.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000316 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000317
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000318 echo -n "testing --until=mm:ss.sss (encode) $desc... "
319 run_flac $eopt --until=0:03.9001 -o z50c.until0:03.9001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
320 run_flac $dopt -o z50c.until0:03.9001.$in_fmt z50c.until0:03.9001.$out_fmt || die "ERROR decoding FLAC file $desc"
321 cmp 50c.until39.$in_fmt z50c.until0:03.9001.$in_fmt || die "ERROR: file mismatch for --until=0:03.9001 (encode) $desc"
322 rm -f z50c.until0:03.9001.$out_fmt z50c.until0:03.9001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000323 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000324
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000325 echo -n "testing --until=-# (encode) $desc... "
326 run_flac $eopt --until=-10 -o z50c.until-10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
327 run_flac $dopt -o z50c.until-10.$in_fmt z50c.until-10.$out_fmt || die "ERROR decoding FLAC file $desc"
328 cmp 50c.until40.$in_fmt z50c.until-10.$in_fmt || die "ERROR: file mismatch for --until=-10 (encode) $desc"
329 rm -f z50c.until-10.$out_fmt z50c.until-10.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000330 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000331
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000332 echo -n "testing --until=-mm:ss (encode) $desc... "
333 run_flac $eopt --until=-0:01 -o z50c.until-0:01.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
334 run_flac $dopt -o z50c.until-0:01.$in_fmt z50c.until-0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
335 cmp 50c.until40.$in_fmt z50c.until-0:01.$in_fmt || die "ERROR: file mismatch for --until=-0:01 (encode) $desc"
336 rm -f z50c.until-0:01.$out_fmt z50c.until-0:01.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000337 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000338
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000339 echo -n "testing --until=-mm:ss.sss (encode) $desc... "
340 run_flac $eopt --until=-0:01.1001 -o z50c.until-0:01.1001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
341 run_flac $dopt -o z50c.until-0:01.1001.$in_fmt z50c.until-0:01.1001.$out_fmt || die "ERROR decoding FLAC file $desc"
342 cmp 50c.until39.$in_fmt z50c.until-0:01.1001.$in_fmt || die "ERROR: file mismatch for --until=-0:01.1001 (encode) $desc"
343 rm -f z50c.until-0:01.1001.$out_fmt z50c.until-0:01.1001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000344 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000345
Josh Coalson8232e292002-12-14 06:22:22 +0000346 #
347 # test --until when decoding
348 #
Josh Coalson8fac5d62002-12-12 03:57:47 +0000349
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000350 run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Josh Coalson8fac5d62002-12-12 03:57:47 +0000351
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000352 echo -n "testing --until=# (decode) $desc... "
353 run_flac $dopt --until=40 -o z50c.until40.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
354 cmp 50c.until40.$in_fmt z50c.until40.$in_fmt || die "ERROR: file mismatch for --until=40 (decode) $desc"
355 rm -f z50c.until40.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000356 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000357
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000358 echo -n "testing --until=mm:ss (decode) $desc... "
359 run_flac $dopt --until=0:04 -o z50c.until0:04.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
360 cmp 50c.until40.$in_fmt z50c.until0:04.$in_fmt || die "ERROR: file mismatch for --until=0:04 (decode) $desc"
361 rm -f z50c.until0:04.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000362 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000363
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000364 echo -n "testing --until=mm:ss.sss (decode) $desc... "
365 run_flac $dopt --until=0:03.9001 -o z50c.until0:03.9001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
366 cmp 50c.until39.$in_fmt z50c.until0:03.9001.$in_fmt || die "ERROR: file mismatch for --until=0:03.9001 (decode) $desc"
367 rm -f z50c.until0:03.9001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000368 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000369
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000370 echo -n "testing --until=-# (decode) $desc... "
371 run_flac $dopt --until=-10 -o z50c.until-10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
372 cmp 50c.until40.$in_fmt z50c.until-10.$in_fmt || die "ERROR: file mismatch for --until=-10 (decode) $desc"
373 rm -f z50c.until-10.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000374 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000375
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000376 echo -n "testing --until=-mm:ss (decode) $desc... "
377 run_flac $dopt --until=-0:01 -o z50c.until-0:01.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
378 cmp 50c.until40.$in_fmt z50c.until-0:01.$in_fmt || die "ERROR: file mismatch for --until=-0:01 (decode) $desc"
379 rm -f z50c.until-0:01.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000380 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000381
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000382 echo -n "testing --until=-mm:ss.sss (decode) $desc... "
383 run_flac $dopt --until=-0:01.1001 -o z50c.until-0:01.1001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
384 cmp 50c.until39.$in_fmt z50c.until-0:01.1001.$in_fmt || die "ERROR: file mismatch for --until=-0:01.1001 (decode) $desc"
385 rm -f z50c.until-0:01.1001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000386 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000387
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000388 rm -f z50c.$out_fmt
Josh Coalson8fac5d62002-12-12 03:57:47 +0000389
Josh Coalson8232e292002-12-14 06:22:22 +0000390 #
391 # test --skip and --until when encoding
392 #
Josh Coalson8fac5d62002-12-12 03:57:47 +0000393
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000394 echo -n "testing --skip=10 --until=# (encode) $desc... "
395 run_flac $eopt --skip=10 --until=40 -o z50c.skip10.until40.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
396 run_flac $dopt -o z50c.skip10.until40.$in_fmt z50c.skip10.until40.$out_fmt || die "ERROR decoding FLAC file $desc"
397 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until40.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=40 (encode) $desc"
398 rm -f z50c.skip10.until40.$out_fmt z50c.skip10.until40.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000399 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000400
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000401 echo -n "testing --skip=10 --until=mm:ss (encode) $desc... "
402 run_flac $eopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
403 run_flac $dopt -o z50c.skip10.until0:04.$in_fmt z50c.skip10.until0:04.$out_fmt || die "ERROR decoding FLAC file $desc"
404 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until0:04.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=0:04 (encode) $desc"
405 rm -f z50c.skip10.until0:04.$out_fmt z50c.skip10.until0:04.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000406 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000407
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000408 echo -n "testing --skip=10 --until=mm:ss.sss (encode) $desc... "
409 run_flac $eopt --skip=10 --until=0:03.9001 -o z50c.skip10.until0:03.9001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
410 run_flac $dopt -o z50c.skip10.until0:03.9001.$in_fmt z50c.skip10.until0:03.9001.$out_fmt || die "ERROR decoding FLAC file $desc"
411 cmp 50c.skip10.until39.$in_fmt z50c.skip10.until0:03.9001.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=0:03.9001 (encode) $desc"
412 rm -f z50c.skip10.until0:03.9001.$out_fmt z50c.skip10.until0:03.9001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000413 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000414
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000415 echo -n "testing --skip=10 --until=+# (encode) $desc... "
416 run_flac $eopt --skip=10 --until=+30 -o z50c.skip10.until+30.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
417 run_flac $dopt -o z50c.skip10.until+30.$in_fmt z50c.skip10.until+30.$out_fmt || die "ERROR decoding FLAC file $desc"
418 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until+30.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=+30 (encode) $desc"
419 rm -f z50c.skip10.until+30.$out_fmt z50c.skip10.until+30.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000420 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000421
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000422 echo -n "testing --skip=10 --until=+mm:ss (encode) $desc... "
423 run_flac $eopt --skip=10 --until=+0:03 -o z50c.skip10.until+0:03.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
424 run_flac $dopt -o z50c.skip10.until+0:03.$in_fmt z50c.skip10.until+0:03.$out_fmt || die "ERROR decoding FLAC file $desc"
425 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until+0:03.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=+0:03 (encode) $desc"
426 rm -f z50c.skip10.until+0:03.$out_fmt z50c.skip10.until+0:03.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000427 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000428
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000429 echo -n "testing --skip=10 --until=+mm:ss.sss (encode) $desc... "
430 run_flac $eopt --skip=10 --until=+0:02.9001 -o z50c.skip10.until+0:02.9001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
431 run_flac $dopt -o z50c.skip10.until+0:02.9001.$in_fmt z50c.skip10.until+0:02.9001.$out_fmt || die "ERROR decoding FLAC file $desc"
432 cmp 50c.skip10.until39.$in_fmt z50c.skip10.until+0:02.9001.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=+0:02.9001 (encode) $desc"
433 rm -f z50c.skip10.until+0:02.9001.$out_fmt z50c.skip10.until+0:02.9001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000434 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000435
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000436 echo -n "testing --skip=10 --until=-# (encode) $desc... "
437 run_flac $eopt --skip=10 --until=-10 -o z50c.skip10.until-10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
438 run_flac $dopt -o z50c.skip10.until-10.$in_fmt z50c.skip10.until-10.$out_fmt || die "ERROR decoding FLAC file $desc"
439 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until-10.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-10 (encode) $desc"
440 rm -f z50c.skip10.until-10.$out_fmt z50c.skip10.until-10.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000441 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000442
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000443 echo -n "testing --skip=10 --until=-mm:ss (encode) $desc... "
444 run_flac $eopt --skip=10 --until=-0:01 -o z50c.skip10.until-0:01.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
445 run_flac $dopt -o z50c.skip10.until-0:01.$in_fmt z50c.skip10.until-0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
446 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until-0:01.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-0:01 (encode) $desc"
447 rm -f z50c.skip10.until-0:01.$out_fmt z50c.skip10.until-0:01.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000448 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000449
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000450 echo -n "testing --skip=10 --until=-mm:ss.sss (encode) $desc... "
451 run_flac $eopt --skip=10 --until=-0:01.1001 -o z50c.skip10.until-0:01.1001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
452 run_flac $dopt -o z50c.skip10.until-0:01.1001.$in_fmt z50c.skip10.until-0:01.1001.$out_fmt || die "ERROR decoding FLAC file $desc"
453 cmp 50c.skip10.until39.$in_fmt z50c.skip10.until-0:01.1001.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-0:01.1001 (encode) $desc"
454 rm -f z50c.skip10.until-0:01.1001.$out_fmt z50c.skip10.until-0:01.1001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000455 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000456
Josh Coalson8232e292002-12-14 06:22:22 +0000457 #
458 # test --skip and --until when decoding
459 #
Josh Coalson8fac5d62002-12-12 03:57:47 +0000460
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000461 run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Josh Coalson8fac5d62002-12-12 03:57:47 +0000462
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000463 echo -n "testing --skip=10 --until=# (decode) $desc... "
464 run_flac $dopt --skip=10 --until=40 -o z50c.skip10.until40.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
465 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until40.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=40 (decode) $desc"
466 rm -f z50c.skip10.until40.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000467 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000468
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000469 echo -n "testing --skip=10 --until=mm:ss (decode) $desc... "
470 run_flac $dopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
471 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until0:04.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=0:04 (decode) $desc"
472 rm -f z50c.skip10.until0:04.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000473 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000474
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000475 echo -n "testing --skip=10 --until=mm:ss.sss (decode) $desc... "
476 run_flac $dopt --skip=10 --until=0:03.9001 -o z50c.skip10.until0:03.9001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
477 cmp 50c.skip10.until39.$in_fmt z50c.skip10.until0:03.9001.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=0:03.9001 (decode) $desc"
478 rm -f z50c.skip10.until0:03.9001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000479 echo OK
Josh Coalson8fac5d62002-12-12 03:57:47 +0000480
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000481 echo -n "testing --skip=10 --until=-# (decode) $desc... "
482 run_flac $dopt --skip=10 --until=-10 -o z50c.skip10.until-10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
483 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until-10.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-10 (decode) $desc"
484 rm -f z50c.skip10.until-10.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000485 echo OK
486
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000487 echo -n "testing --skip=10 --until=-mm:ss (decode) $desc... "
488 run_flac $dopt --skip=10 --until=-0:01 -o z50c.skip10.until-0:01.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
489 cmp 50c.skip10.until40.$in_fmt z50c.skip10.until-0:01.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-0:01 (decode) $desc"
490 rm -f z50c.skip10.until-0:01.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000491 echo OK
492
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000493 echo -n "testing --skip=10 --until=-mm:ss.sss (decode) $desc... "
494 run_flac $dopt --skip=10 --until=-0:01.1001 -o z50c.skip10.until-0:01.1001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
495 cmp 50c.skip10.until39.$in_fmt z50c.skip10.until-0:01.1001.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-0:01.1001 (decode) $desc"
496 rm -f z50c.skip10.until-0:01.1001.$in_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000497 echo OK
498
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000499 rm -f z50c.$out_fmt
Josh Coalson8232e292002-12-14 06:22:22 +0000500}
501
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000502test_skip_until raw flac
503test_skip_until wav flac
504test_skip_until aiff flac
Josh Coalson463d0f82002-12-10 06:41:27 +0000505
Josh Coalson3e3ad0c2004-07-07 07:39:59 +0000506if [ $has_ogg = "yes" ] ; then
507 test_skip_until raw ogg
508 test_skip_until wav ogg
509 test_skip_until aiff ogg
510fi
Josh Coalson9238a142002-12-21 03:29:26 +0000511
Josh Coalson29f52ea2004-07-30 00:22:46 +0000512echo "Testing seek extremes:"
513
514run_flac --verify --force --silent --force-raw-format --endian=big --sign=signed --sample-rate=44100 --bps=16 --channels=2 --blocksize=576 noise.raw || die "ERROR generating FLAC file"
515
516total_samples=`metaflac --show-total-samples noise.flac`
517[ $? = 0 ] || die "ERROR getting total sample count from noise.flac"
518
519echo -n "Testing --skip=0... "
Josh Coalson4f4beee2004-07-30 00:35:51 +0000520run_flac $wav_dopt --skip=0 -o z.wav noise.flac || die "ERROR decoding FLAC file noise.flac"
Josh Coalson29f52ea2004-07-30 00:22:46 +0000521echo OK
522
523for delta in 2 1 ; do
524 n=`expr $total_samples - $delta`
525 echo -n "Testing --skip=$n... "
Josh Coalson4f4beee2004-07-30 00:35:51 +0000526 run_flac $wav_dopt --skip=$n -o z.wav noise.flac || die "ERROR decoding FLAC file noise.flac"
Josh Coalson29f52ea2004-07-30 00:22:46 +0000527 echo OK
528done
529
530rm noise.flac z.wav
531
532
Josh Coalson9238a142002-12-21 03:29:26 +0000533############################################################################
Josh Coalson03a5a692004-07-17 00:23:17 +0000534# test --cue
535############################################################################
536
537#
538# create the cue sheet
539#
540cuesheet=cuetest.cue
541cat > $cuesheet << EOF
542CATALOG 1234567890123
543FILE "blah" WAVE
544 TRACK 01 AUDIO
545 INDEX 01 0
546 INDEX 02 10
547 INDEX 03 20
548 TRACK 02 AUDIO
549 INDEX 01 30
550 TRACK 04 AUDIO
551 INDEX 01 40
552EOF
553
554test_cue ()
555{
556 in_fmt=$1
557 out_fmt=$2
558
559 [ "$in_fmt" = wav ] || [ "$in_fmt" = aiff ] || [ "$in_fmt" = raw ] || die "ERROR: internal error, bad 'in' format '$in_fmt'"
560
561 [ "$out_fmt" = flac ] || [ "$out_fmt" = ogg ] || die "ERROR: internal error, bad 'out' format '$out_fmt'"
562
563 if [ $in_fmt = raw ] ; then
564 eopt="$raw_eopt"
565 dopt="$raw_dopt"
566 else
567 eopt="$wav_eopt"
568 dopt="$wav_dopt"
569 fi
570
571 if [ $out_fmt = ogg ] ; then
572 eopt="--ogg $eopt"
573 fi
574
575 desc="($in_fmt<->$out_fmt)"
576
577 #
578 # for this we need just need just one FLAC file; --cue only works while decoding
579 #
580 run_flac $eopt --cuesheet=$cuesheet -o z50c.cue.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
581
582 # To make it easy to translate from cue point to sample numbers, the
583 # file has a sample rate of 10 Hz and a cuesheet like so:
584 #
585 # TRACK 01, INDEX 01 : 0:00.00 -> sample 0
586 # TRACK 01, INDEX 02 : 0:01.00 -> sample 10
587 # TRACK 01, INDEX 03 : 0:02.00 -> sample 20
588 # TRACK 02, INDEX 01 : 0:03.00 -> sample 30
589 # TRACK 04, INDEX 01 : 0:04.00 -> sample 40
590 #
591 echo -n "testing --cue=- $desc... "
592 run_flac $dopt -o z50c.cue.$in_fmt --cue=- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
593 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=- $desc"
594 rm -f z50c.cue.$in_fmt
595 echo OK
596
597 echo -n "testing --cue=1.0 $desc... "
598 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
599 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0 $desc"
600 rm -f z50c.cue.$in_fmt
601 echo OK
602
603 echo -n "testing --cue=1.0- $desc... "
604 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
605 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0- $desc"
606 rm -f z50c.cue.$in_fmt
607 echo OK
608
609 echo -n "testing --cue=1.1 $desc... "
610 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
611 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1 $desc"
612 rm -f z50c.cue.$in_fmt
613 echo OK
614
615 echo -n "testing --cue=1.1- $desc... "
616 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
617 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1- $desc"
618 rm -f z50c.cue.$in_fmt
619 echo OK
620
621 echo -n "testing --cue=1.2 $desc... "
622 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
623 cmp 50c.skip10.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2 $desc"
624 rm -f z50c.cue.$in_fmt
625 echo OK
626
627 echo -n "testing --cue=1.2- $desc... "
628 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
629 cmp 50c.skip10.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2- $desc"
630 rm -f z50c.cue.$in_fmt
631 echo OK
632
633 echo -n "testing --cue=1.4 $desc... "
634 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
635 cmp 50c.skip20.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4 $desc"
636 rm -f z50c.cue.$in_fmt
637 echo OK
638
639 echo -n "testing --cue=1.4- $desc... "
640 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
641 cmp 50c.skip20.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4- $desc"
642 rm -f z50c.cue.$in_fmt
643 echo OK
644
645 echo -n "testing --cue=-5.0 $desc... "
646 run_flac $dopt -o z50c.cue.$in_fmt --cue=-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
647 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-5.0 $desc"
648 rm -f z50c.cue.$in_fmt
649 echo OK
650
651 echo -n "testing --cue=-4.1 $desc... "
652 run_flac $dopt -o z50c.cue.$in_fmt --cue=-4.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
653 cmp 50c.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-4.1 $desc"
654 rm -f z50c.cue.$in_fmt
655 echo OK
656
657 echo -n "testing --cue=-3.1 $desc... "
658 run_flac $dopt -o z50c.cue.$in_fmt --cue=-3.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
659 cmp 50c.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-3.1 $desc"
660 rm -f z50c.cue.$in_fmt
661 echo OK
662
663 echo -n "testing --cue=-1.4 $desc... "
664 run_flac $dopt -o z50c.cue.$in_fmt --cue=-1.4 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
665 cmp 50c.until30.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-1.4 $desc"
666 rm -f z50c.cue.$in_fmt
667 echo OK
668
669 echo -n "testing --cue=1.0-5.0 $desc... "
670 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
671 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0-5.0 $desc"
672 rm -f z50c.cue.$in_fmt
673 echo OK
674
675 echo -n "testing --cue=1.1-5.0 $desc... "
676 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
677 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1-5.0 $desc"
678 rm -f z50c.cue.$in_fmt
679 echo OK
680
681 echo -n "testing --cue=1.2-4.1 $desc... "
682 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2-4.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
683 cmp 50c.skip10.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2-4.1 $desc"
684 rm -f z50c.cue.$in_fmt
685 echo OK
686
687 echo -n "testing --cue=1.4-2.0 $desc... "
688 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4-2.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
689 cmp 50c.skip20.until30.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4-2.0 $desc"
690 rm -f z50c.cue.$in_fmt
691 echo OK
692
693 rm -f z50c.cue.$out_fmt
694}
695
696test_cue raw flac
697test_cue wav flac
698test_cue aiff flac
699
700if [ $has_ogg = "yes" ] ; then
701 test_cue raw ogg
702 test_cue wav ogg
703 test_cue aiff ogg
704fi
705
706############################################################################
Josh Coalson9238a142002-12-21 03:29:26 +0000707# test 'fixup' code that happens when a FLAC file with total_samples == 0
708# in the STREAMINFO block is converted to WAVE or AIFF, requiring the
709# decoder go back and fix up the chunk headers
710############################################################################
711
712echo -n "WAVE fixup test... "
713echo -n "prepare... "
714convert_to_wav noise || die "ERROR creating reference WAVE"
715echo -n "encode... "
716cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
717echo -n "decode... "
718run_flac $wav_dopt fixup.flac -o fixup.wav || die "ERROR decoding FLAC file"
719echo -n "compare... "
720cmp noise.wav fixup.wav || die "ERROR: file mismatch"
721echo OK
722rm -f noise.wav fixup.wav fixup.flac
723
724echo -n "AIFF fixup test... "
725echo -n "prepare... "
726convert_to_aiff noise || die "ERROR creating reference AIFF"
727echo -n "encode... "
728cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
729echo -n "decode... "
730run_flac $wav_dopt fixup.flac -o fixup.aiff || die "ERROR decoding FLAC file"
731echo -n "compare... "
732cmp noise.aiff fixup.aiff || die "ERROR: file mismatch"
733echo OK
734rm -f noise.aiff fixup.aiff fixup.flac
735
736
737############################################################################
Josh Coalson463d0f82002-12-10 06:41:27 +0000738# multi-file tests
Josh Coalson9238a142002-12-21 03:29:26 +0000739############################################################################
Josh Coalson463d0f82002-12-10 06:41:27 +0000740
Josh Coalson463d0f82002-12-10 06:41:27 +0000741echo "Generating multiple input files from noise..."
Josh Coalson0bb57d02004-07-16 00:50:42 +0000742run_flac --verify --force --silent --force-raw-format --endian=big --sign=signed --sample-rate=44100 --bps=16 --channels=2 noise.raw || die "ERROR generating FLAC file"
743run_flac --decode --force --silent noise.flac || die "ERROR generating WAVE file"
Josh Coalson463d0f82002-12-10 06:41:27 +0000744rm -f noise.flac
745mv noise.wav file0.wav
746cp file0.wav file1.wav
747cp file1.wav file2.wav
748
749test_multifile ()
750{
751 streamtype=$1
752 sector_align=$2
753 encode_options="$3"
754
755 if [ $streamtype = ogg ] ; then
756 suffix=ogg
757 encode_options="$encode_options --ogg"
758 else
759 suffix=flac
760 fi
761
762 if [ $sector_align = sector_align ] ; then
763 encode_options="$encode_options --sector-align"
764 fi
765
Josh Coalson0bb57d02004-07-16 00:50:42 +0000766 run_flac --force $encode_options file0.wav file1.wav file2.wav || die "ERROR"
Josh Coalson463d0f82002-12-10 06:41:27 +0000767 for n in 0 1 2 ; do
768 mv file$n.$suffix file${n}x.$suffix
769 done
Josh Coalson0bb57d02004-07-16 00:50:42 +0000770 run_flac --force --decode file0x.$suffix file1x.$suffix file2x.$suffix || die "ERROR"
Josh Coalson463d0f82002-12-10 06:41:27 +0000771 if [ $sector_align != sector_align ] ; then
772 for n in 0 1 2 ; do
Josh Coalson8fac5d62002-12-12 03:57:47 +0000773 cmp file$n.wav file${n}x.wav || die "ERROR: file mismatch on file #$n"
Josh Coalson463d0f82002-12-10 06:41:27 +0000774 done
775 fi
776 for n in 0 1 2 ; do
777 rm -f file${n}x.$suffix file${n}x.wav
778 done
779}
780
781echo "Testing multiple files without verify..."
782test_multifile flac no_sector_align ""
783
784echo "Testing multiple files with verify..."
785test_multifile flac no_sector_align "--verify"
786
787echo "Testing multiple files with --sector-align, without verify..."
788test_multifile flac sector_align ""
789
790echo "Testing multiple files with --sector-align, with verify..."
791test_multifile flac sector_align "--verify"
792
793if [ $has_ogg = "yes" ] ; then
794 echo "Testing multiple files with --ogg, without verify..."
795 test_multifile ogg no_sector_align ""
796
797 echo "Testing multiple files with --ogg, with verify..."
798 test_multifile ogg no_sector_align "--verify"
799
800 echo "Testing multiple files with --ogg and --sector-align, without verify..."
801 test_multifile ogg sector_align ""
802
803 echo "Testing multiple files with --ogg and --sector-align, with verify..."
804 test_multifile sector_align ogg "--verify"
805
806 echo "Testing multiple files with --ogg and --serial-number, with verify..."
807 test_multifile ogg no_sector_align "--serial-number=321 --verify"
808fi