blob: f1b6c6fc6004b5bbcf34820a258f46ba37e80532 [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
512############################################################################
Josh Coalson03a5a692004-07-17 00:23:17 +0000513# test --cue
514############################################################################
515
516#
517# create the cue sheet
518#
519cuesheet=cuetest.cue
520cat > $cuesheet << EOF
521CATALOG 1234567890123
522FILE "blah" WAVE
523 TRACK 01 AUDIO
524 INDEX 01 0
525 INDEX 02 10
526 INDEX 03 20
527 TRACK 02 AUDIO
528 INDEX 01 30
529 TRACK 04 AUDIO
530 INDEX 01 40
531EOF
532
533test_cue ()
534{
535 in_fmt=$1
536 out_fmt=$2
537
538 [ "$in_fmt" = wav ] || [ "$in_fmt" = aiff ] || [ "$in_fmt" = raw ] || die "ERROR: internal error, bad 'in' format '$in_fmt'"
539
540 [ "$out_fmt" = flac ] || [ "$out_fmt" = ogg ] || die "ERROR: internal error, bad 'out' format '$out_fmt'"
541
542 if [ $in_fmt = raw ] ; then
543 eopt="$raw_eopt"
544 dopt="$raw_dopt"
545 else
546 eopt="$wav_eopt"
547 dopt="$wav_dopt"
548 fi
549
550 if [ $out_fmt = ogg ] ; then
551 eopt="--ogg $eopt"
552 fi
553
554 desc="($in_fmt<->$out_fmt)"
555
556 #
557 # for this we need just need just one FLAC file; --cue only works while decoding
558 #
559 run_flac $eopt --cuesheet=$cuesheet -o z50c.cue.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
560
561 # To make it easy to translate from cue point to sample numbers, the
562 # file has a sample rate of 10 Hz and a cuesheet like so:
563 #
564 # TRACK 01, INDEX 01 : 0:00.00 -> sample 0
565 # TRACK 01, INDEX 02 : 0:01.00 -> sample 10
566 # TRACK 01, INDEX 03 : 0:02.00 -> sample 20
567 # TRACK 02, INDEX 01 : 0:03.00 -> sample 30
568 # TRACK 04, INDEX 01 : 0:04.00 -> sample 40
569 #
570 echo -n "testing --cue=- $desc... "
571 run_flac $dopt -o z50c.cue.$in_fmt --cue=- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
572 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=- $desc"
573 rm -f z50c.cue.$in_fmt
574 echo OK
575
576 echo -n "testing --cue=1.0 $desc... "
577 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
578 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0 $desc"
579 rm -f z50c.cue.$in_fmt
580 echo OK
581
582 echo -n "testing --cue=1.0- $desc... "
583 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
584 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0- $desc"
585 rm -f z50c.cue.$in_fmt
586 echo OK
587
588 echo -n "testing --cue=1.1 $desc... "
589 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
590 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1 $desc"
591 rm -f z50c.cue.$in_fmt
592 echo OK
593
594 echo -n "testing --cue=1.1- $desc... "
595 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
596 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1- $desc"
597 rm -f z50c.cue.$in_fmt
598 echo OK
599
600 echo -n "testing --cue=1.2 $desc... "
601 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
602 cmp 50c.skip10.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2 $desc"
603 rm -f z50c.cue.$in_fmt
604 echo OK
605
606 echo -n "testing --cue=1.2- $desc... "
607 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
608 cmp 50c.skip10.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2- $desc"
609 rm -f z50c.cue.$in_fmt
610 echo OK
611
612 echo -n "testing --cue=1.4 $desc... "
613 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
614 cmp 50c.skip20.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4 $desc"
615 rm -f z50c.cue.$in_fmt
616 echo OK
617
618 echo -n "testing --cue=1.4- $desc... "
619 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
620 cmp 50c.skip20.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4- $desc"
621 rm -f z50c.cue.$in_fmt
622 echo OK
623
624 echo -n "testing --cue=-5.0 $desc... "
625 run_flac $dopt -o z50c.cue.$in_fmt --cue=-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
626 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-5.0 $desc"
627 rm -f z50c.cue.$in_fmt
628 echo OK
629
630 echo -n "testing --cue=-4.1 $desc... "
631 run_flac $dopt -o z50c.cue.$in_fmt --cue=-4.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
632 cmp 50c.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-4.1 $desc"
633 rm -f z50c.cue.$in_fmt
634 echo OK
635
636 echo -n "testing --cue=-3.1 $desc... "
637 run_flac $dopt -o z50c.cue.$in_fmt --cue=-3.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
638 cmp 50c.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-3.1 $desc"
639 rm -f z50c.cue.$in_fmt
640 echo OK
641
642 echo -n "testing --cue=-1.4 $desc... "
643 run_flac $dopt -o z50c.cue.$in_fmt --cue=-1.4 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
644 cmp 50c.until30.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-1.4 $desc"
645 rm -f z50c.cue.$in_fmt
646 echo OK
647
648 echo -n "testing --cue=1.0-5.0 $desc... "
649 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
650 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0-5.0 $desc"
651 rm -f z50c.cue.$in_fmt
652 echo OK
653
654 echo -n "testing --cue=1.1-5.0 $desc... "
655 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
656 cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1-5.0 $desc"
657 rm -f z50c.cue.$in_fmt
658 echo OK
659
660 echo -n "testing --cue=1.2-4.1 $desc... "
661 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2-4.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
662 cmp 50c.skip10.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2-4.1 $desc"
663 rm -f z50c.cue.$in_fmt
664 echo OK
665
666 echo -n "testing --cue=1.4-2.0 $desc... "
667 run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4-2.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
668 cmp 50c.skip20.until30.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4-2.0 $desc"
669 rm -f z50c.cue.$in_fmt
670 echo OK
671
672 rm -f z50c.cue.$out_fmt
673}
674
675test_cue raw flac
676test_cue wav flac
677test_cue aiff flac
678
679if [ $has_ogg = "yes" ] ; then
680 test_cue raw ogg
681 test_cue wav ogg
682 test_cue aiff ogg
683fi
684
685############################################################################
Josh Coalson9238a142002-12-21 03:29:26 +0000686# test 'fixup' code that happens when a FLAC file with total_samples == 0
687# in the STREAMINFO block is converted to WAVE or AIFF, requiring the
688# decoder go back and fix up the chunk headers
689############################################################################
690
691echo -n "WAVE fixup test... "
692echo -n "prepare... "
693convert_to_wav noise || die "ERROR creating reference WAVE"
694echo -n "encode... "
695cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
696echo -n "decode... "
697run_flac $wav_dopt fixup.flac -o fixup.wav || die "ERROR decoding FLAC file"
698echo -n "compare... "
699cmp noise.wav fixup.wav || die "ERROR: file mismatch"
700echo OK
701rm -f noise.wav fixup.wav fixup.flac
702
703echo -n "AIFF fixup test... "
704echo -n "prepare... "
705convert_to_aiff noise || die "ERROR creating reference AIFF"
706echo -n "encode... "
707cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
708echo -n "decode... "
709run_flac $wav_dopt fixup.flac -o fixup.aiff || die "ERROR decoding FLAC file"
710echo -n "compare... "
711cmp noise.aiff fixup.aiff || die "ERROR: file mismatch"
712echo OK
713rm -f noise.aiff fixup.aiff fixup.flac
714
715
716############################################################################
Josh Coalson463d0f82002-12-10 06:41:27 +0000717# multi-file tests
Josh Coalson9238a142002-12-21 03:29:26 +0000718############################################################################
Josh Coalson463d0f82002-12-10 06:41:27 +0000719
Josh Coalson463d0f82002-12-10 06:41:27 +0000720echo "Generating multiple input files from noise..."
Josh Coalson0bb57d02004-07-16 00:50:42 +0000721run_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"
722run_flac --decode --force --silent noise.flac || die "ERROR generating WAVE file"
Josh Coalson463d0f82002-12-10 06:41:27 +0000723rm -f noise.flac
724mv noise.wav file0.wav
725cp file0.wav file1.wav
726cp file1.wav file2.wav
727
728test_multifile ()
729{
730 streamtype=$1
731 sector_align=$2
732 encode_options="$3"
733
734 if [ $streamtype = ogg ] ; then
735 suffix=ogg
736 encode_options="$encode_options --ogg"
737 else
738 suffix=flac
739 fi
740
741 if [ $sector_align = sector_align ] ; then
742 encode_options="$encode_options --sector-align"
743 fi
744
Josh Coalson0bb57d02004-07-16 00:50:42 +0000745 run_flac --force $encode_options file0.wav file1.wav file2.wav || die "ERROR"
Josh Coalson463d0f82002-12-10 06:41:27 +0000746 for n in 0 1 2 ; do
747 mv file$n.$suffix file${n}x.$suffix
748 done
Josh Coalson0bb57d02004-07-16 00:50:42 +0000749 run_flac --force --decode file0x.$suffix file1x.$suffix file2x.$suffix || die "ERROR"
Josh Coalson463d0f82002-12-10 06:41:27 +0000750 if [ $sector_align != sector_align ] ; then
751 for n in 0 1 2 ; do
Josh Coalson8fac5d62002-12-12 03:57:47 +0000752 cmp file$n.wav file${n}x.wav || die "ERROR: file mismatch on file #$n"
Josh Coalson463d0f82002-12-10 06:41:27 +0000753 done
754 fi
755 for n in 0 1 2 ; do
756 rm -f file${n}x.$suffix file${n}x.wav
757 done
758}
759
760echo "Testing multiple files without verify..."
761test_multifile flac no_sector_align ""
762
763echo "Testing multiple files with verify..."
764test_multifile flac no_sector_align "--verify"
765
766echo "Testing multiple files with --sector-align, without verify..."
767test_multifile flac sector_align ""
768
769echo "Testing multiple files with --sector-align, with verify..."
770test_multifile flac sector_align "--verify"
771
772if [ $has_ogg = "yes" ] ; then
773 echo "Testing multiple files with --ogg, without verify..."
774 test_multifile ogg no_sector_align ""
775
776 echo "Testing multiple files with --ogg, with verify..."
777 test_multifile ogg no_sector_align "--verify"
778
779 echo "Testing multiple files with --ogg and --sector-align, without verify..."
780 test_multifile ogg sector_align ""
781
782 echo "Testing multiple files with --ogg and --sector-align, with verify..."
783 test_multifile sector_align ogg "--verify"
784
785 echo "Testing multiple files with --ogg and --serial-number, with verify..."
786 test_multifile ogg no_sector_align "--serial-number=321 --verify"
787fi