initial import, copied from test_libFLAC/
[flac.git] / test / test_flac.sh
index aeae8bb..4876f55 100755 (executable)
@@ -1,7 +1,7 @@
 #!/bin/sh
 
 #  FLAC - Free Lossless Audio Codec
-#  Copyright (C) 2001,2002  Josh Coalson
+#  Copyright (C) 2001,2002,2003  Josh Coalson
 #
 #  This program is part of FLAC; you can redistribute it and/or
 #  modify it under the terms of the GNU General Public License
@@ -32,7 +32,7 @@ flac --help 1>/dev/null 2>/dev/null || die "ERROR can't find flac executable"
 run_flac ()
 {
        if [ "$FLAC__VALGRIND" = yes ] ; then
-               valgrind --leak-check=yes --show-reachable=yes --num-callers=10 --logfile-fd=4 flac $* 4>>valgrind.log
+               valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --logfile-fd=4 flac $* 4>>test_flac.valgrind.log
        else
                flac $*
        fi
@@ -47,12 +47,74 @@ else
        echo "flac --ogg doesn't work"
 fi
 
+
+echo "Generating streams..."
+if [ ! -f wacky1.wav ] ; then
+       test_streams || die "ERROR during test_streams"
+fi
+
+############################################################################
+# basic 'round-trip' tests of various kinds of streams
+############################################################################
+
+rt_test_raw ()
+{
+       f="$1"
+       channels=`echo $f | awk -F- '{print $2}'`
+       bytes_per_sample=`echo $f | awk -F- '{print $3}'`
+       bps=`expr $bytes_per_sample '*' 8`
+       echo -n "round-trip test ($f) encode... "
+       run_flac --silent --verify --force-raw-format --endian=little --sign=signed --sample-rate=44100 --bps=$bps --channels=$channels $f -o rt.flac || die "ERROR"
+       echo -n "decode... "
+       run_flac --silent --decode --force-raw-format --endian=little --sign=signed -o rt.raw rt.flac || die "ERROR"
+       echo -n "compare... "
+       cmp $f rt.raw || die "ERROR: file mismatch"
+       echo "OK"
+       rm -f rt.flac rt.raw
+}
+
+rt_test_wav ()
+{
+       f="$1"
+       echo -n "round-trip test ($f) encode... "
+       run_flac --silent --verify $f -o rt.flac || die "ERROR"
+       echo -n "decode... "
+       run_flac --silent --decode -o rt.wav rt.flac || die "ERROR"
+       echo -n "compare... "
+       cmp $f rt.wav || die "ERROR: file mismatch"
+       echo "OK"
+       rm -f rt.flac rt.wav
+}
+
+rt_test_aiff ()
+{
+       f="$1"
+       echo -n "round-trip test ($f) encode... "
+       run_flac --silent --verify $f -o rt.flac || die "ERROR"
+       echo -n "decode... "
+       run_flac --silent --decode -o rt.aiff rt.flac || die "ERROR"
+       echo -n "compare... "
+       cmp $f rt.aiff || die "ERROR: file mismatch"
+       echo "OK"
+       rm -f rt.flac rt.aiff
+}
+
+for f in rt-*.raw ; do
+       rt_test_raw $f
+done
+for f in rt-*.wav ; do
+       rt_test_wav $f
+done
+for f in rt-*.aiff ; do
+       rt_test_aiff $f
+done
+
 ############################################################################
 # test --skip and --until
 ############################################################################
 
 #
-# first make some chopped-up files
+# first make some chopped-up raw files
 #
 echo "abcdefghijklmnopqrstuvwxyz1234567890ABCDEFGHIJKLMN" > master.raw
 dddie="die ERROR: creating files for --skip/--until tests"
@@ -64,271 +126,346 @@ dd if=master.raw ibs=1 count=39 of=50c.until39.raw 2>/dev/null || $dddie
 dd if=master.raw ibs=1 skip=10 count=30 of=50c.skip10.until40.raw 2>/dev/null || $dddie
 dd if=master.raw ibs=1 skip=10 count=29 of=50c.skip10.until39.raw 2>/dev/null || $dddie
 
-eopt="--silent --verify --lax --force-raw-format --endian=big --sign=signed --sample-rate=10 --bps=8 --channels=1"
-dopt="--silent --decode --force-raw-format --endian=big --sign=signed"
-
-#
-# test --skip when encoding
-#
-
-echo -n "testing --skip=# (encode)... "
-run_flac $eopt --skip=10 -o z50c.skip10.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.raw z50c.skip10.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.raw z50c.skip10.raw || die "ERROR: file mismatch for --skip=10 (encode)"
-rm -f z50c.skip10.flac z50c.skip10.raw
-echo OK
+wav_eopt="--silent --verify --lax"
+wav_dopt="--silent --decode"
 
-echo -n "testing --skip=mm:ss (encode)... "
-run_flac $eopt --skip=0:01 -o z50c.skip0:01.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip0:01.raw z50c.skip0:01.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.raw z50c.skip0:01.raw || die "ERROR: file mismatch for --skip=0:01 (encode)"
-rm -f z50c.skip0:01.flac z50c.skip0:01.raw
-echo OK
-
-echo -n "testing --skip=mm:ss.sss (encode)... "
-run_flac $eopt --skip=0:01.1001 -o z50c.skip0:01.1001.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip0:01.1001.raw z50c.skip0:01.1001.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip11.raw z50c.skip0:01.1001.raw || die "ERROR: file mismatch for --skip=0:01.1001 (encode)"
-rm -f z50c.skip0:01.1001.flac z50c.skip0:01.1001.raw
-echo OK
+raw_eopt="$wav_eopt --force-raw-format --endian=big --sign=signed --sample-rate=10 --bps=8 --channels=1"
+raw_dopt="$wav_dopt --force-raw-format --endian=big --sign=signed"
 
 #
-# test --skip when decoding
+# convert them to WAVE and AIFF files
 #
+convert_to_wav ()
+{
+       run_flac $raw_eopt $1.raw || die "ERROR converting $1.raw to WAVE"
+       run_flac $wav_dopt $1.flac || die "ERROR converting $1.raw to WAVE"
+}
+convert_to_wav 50c
+convert_to_wav 50c.skip10
+convert_to_wav 50c.skip11
+convert_to_wav 50c.until40
+convert_to_wav 50c.until39
+convert_to_wav 50c.skip10.until40
+convert_to_wav 50c.skip10.until39
+
+convert_to_aiff ()
+{
+       run_flac $raw_eopt $1.raw || die "ERROR converting $1.raw to AIFF"
+       run_flac $wav_dopt $1.flac -o $1.aiff || die "ERROR converting $1.raw to AIFF"
+}
+convert_to_aiff 50c
+convert_to_aiff 50c.skip10
+convert_to_aiff 50c.skip11
+convert_to_aiff 50c.until40
+convert_to_aiff 50c.until39
+convert_to_aiff 50c.skip10.until40
+convert_to_aiff 50c.skip10.until39
+
+test_skip_until ()
+{
+       fmt=$1
 
-echo -n "testing --skip=# (decode)... "
-run_flac $eopt -o z50c.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt --skip=10 -o z50c.skip10.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.raw z50c.skip10.raw || die "ERROR: file mismatch for --skip=10 (decode)"
-rm -f z50c.skip10.raw
-echo OK
-
-echo -n "testing --skip=mm:ss (decode)... "
-run_flac $dopt --skip=0:01 -o z50c.skip0:01.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.raw z50c.skip0:01.raw || die "ERROR: file mismatch for --skip=0:01 (decode)"
-rm -f z50c.skip0:01.raw
-echo OK
-
-echo -n "testing --skip=mm:ss.sss (decode)... "
-run_flac $dopt --skip=0:01.1001 -o z50c.skip0:01.1001.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip11.raw z50c.skip0:01.1001.raw || die "ERROR: file mismatch for --skip=0:01.1001 (decode)"
-rm -f z50c.skip0:01.1001.raw
-echo OK
-
-rm -f z50c.flac
-
-#
-# test --until when encoding
-#
-
-echo -n "testing --until=# (encode)... "
-run_flac $eopt --until=40 -o z50c.until40.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.until40.raw z50c.until40.flac || die "ERROR decoding FLAC file"
-cmp 50c.until40.raw z50c.until40.raw || die "ERROR: file mismatch for --until=40 (encode)"
-rm -f z50c.until40.flac z50c.until40.raw
-echo OK
-
-echo -n "testing --until=mm:ss (encode)... "
-run_flac $eopt --until=0:04 -o z50c.until0:04.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.until0:04.raw z50c.until0:04.flac || die "ERROR decoding FLAC file"
-cmp 50c.until40.raw z50c.until0:04.raw || die "ERROR: file mismatch for --until=0:04 (encode)"
-rm -f z50c.until0:04.flac z50c.until0:04.raw
-echo OK
-
-echo -n "testing --until=mm:ss.sss (encode)... "
-run_flac $eopt --until=0:03.9001 -o z50c.until0:03.9001.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.until0:03.9001.raw z50c.until0:03.9001.flac || die "ERROR decoding FLAC file"
-cmp 50c.until39.raw z50c.until0:03.9001.raw || die "ERROR: file mismatch for --until=0:03.9001 (encode)"
-rm -f z50c.until0:03.9001.flac z50c.until0:03.9001.raw
-echo OK
-
-echo -n "testing --until=-# (encode)... "
-run_flac $eopt --until=-10 -o z50c.until-10.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.until-10.raw z50c.until-10.flac || die "ERROR decoding FLAC file"
-cmp 50c.until40.raw z50c.until-10.raw || die "ERROR: file mismatch for --until=-10 (encode)"
-rm -f z50c.until-10.flac z50c.until-10.raw
-echo OK
-
-echo -n "testing --until=-mm:ss (encode)... "
-run_flac $eopt --until=-0:01 -o z50c.until-0:01.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.until-0:01.raw z50c.until-0:01.flac || die "ERROR decoding FLAC file"
-cmp 50c.until40.raw z50c.until-0:01.raw || die "ERROR: file mismatch for --until=-0:01 (encode)"
-rm -f z50c.until-0:01.flac z50c.until-0:01.raw
-echo OK
-
-echo -n "testing --until=-mm:ss.sss (encode)... "
-run_flac $eopt --until=-0:01.1001 -o z50c.until-0:01.1001.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.until-0:01.1001.raw z50c.until-0:01.1001.flac || die "ERROR decoding FLAC file"
-cmp 50c.until39.raw z50c.until-0:01.1001.raw || die "ERROR: file mismatch for --until=-0:01.1001 (encode)"
-rm -f z50c.until-0:01.1001.flac z50c.until-0:01.1001.raw
-echo OK
-
-#
-# test --until when decoding
-#
-
-run_flac $eopt -o z50c.flac 50c.raw || die "ERROR generating FLAC file"
-
-echo -n "testing --until=# (decode)... "
-run_flac $dopt --until=40 -o z50c.until40.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.until40.raw z50c.until40.raw || die "ERROR: file mismatch for --until=40 (decode)"
-rm -f z50c.until40.raw
-echo OK
-
-echo -n "testing --until=mm:ss (decode)... "
-run_flac $dopt --until=0:04 -o z50c.until0:04.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.until40.raw z50c.until0:04.raw || die "ERROR: file mismatch for --until=0:04 (decode)"
-rm -f z50c.until0:04.raw
-echo OK
-
-echo -n "testing --until=mm:ss.sss (decode)... "
-run_flac $dopt --until=0:03.9001 -o z50c.until0:03.9001.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.until39.raw z50c.until0:03.9001.raw || die "ERROR: file mismatch for --until=0:03.9001 (decode)"
-rm -f z50c.until0:03.9001.raw
-echo OK
-
-echo -n "testing --until=-# (decode)... "
-run_flac $dopt --until=-10 -o z50c.until-10.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.until40.raw z50c.until-10.raw || die "ERROR: file mismatch for --until=-10 (decode)"
-rm -f z50c.until-10.raw
-echo OK
-
-echo -n "testing --until=-mm:ss (decode)... "
-run_flac $dopt --until=-0:01 -o z50c.until-0:01.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.until40.raw z50c.until-0:01.raw || die "ERROR: file mismatch for --until=-0:01 (decode)"
-rm -f z50c.until-0:01.raw
-echo OK
-
-echo -n "testing --until=-mm:ss.sss (decode)... "
-run_flac $dopt --until=-0:01.1001 -o z50c.until-0:01.1001.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.until39.raw z50c.until-0:01.1001.raw || die "ERROR: file mismatch for --until=-0:01.1001 (decode)"
-rm -f z50c.until-0:01.1001.raw
-echo OK
-
-rm -f z50c.flac
-
-#
-# test --skip and --until when encoding
-#
-
-echo -n "testing --skip=10 --until=# (encode)... "
-run_flac $eopt --skip=10 --until=40 -o z50c.skip10.until40.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until40.raw z50c.skip10.until40.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until40.raw || die "ERROR: file mismatch for --skip=10 --until=40 (encode)"
-rm -f z50c.skip10.until40.flac z50c.skip10.until40.raw
-echo OK
-
-echo -n "testing --skip=10 --until=mm:ss (encode)... "
-run_flac $eopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until0:04.raw z50c.skip10.until0:04.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until0:04.raw || die "ERROR: file mismatch for --skip=10 --until=0:04 (encode)"
-rm -f z50c.skip10.until0:04.flac z50c.skip10.until0:04.raw
-echo OK
-
-echo -n "testing --skip=10 --until=mm:ss.sss (encode)... "
-run_flac $eopt --skip=10 --until=0:03.9001 -o z50c.skip10.until0:03.9001.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until0:03.9001.raw z50c.skip10.until0:03.9001.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until39.raw z50c.skip10.until0:03.9001.raw || die "ERROR: file mismatch for --skip=10 --until=0:03.9001 (encode)"
-rm -f z50c.skip10.until0:03.9001.flac z50c.skip10.until0:03.9001.raw
-echo OK
-
-echo -n "testing --skip=10 --until=+# (encode)... "
-run_flac $eopt --skip=10 --until=+30 -o z50c.skip10.until+30.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until+30.raw z50c.skip10.until+30.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until+30.raw || die "ERROR: file mismatch for --skip=10 --until=+30 (encode)"
-rm -f z50c.skip10.until+30.flac z50c.skip10.until+30.raw
-echo OK
-
-echo -n "testing --skip=10 --until=+mm:ss (encode)... "
-run_flac $eopt --skip=10 --until=+0:03 -o z50c.skip10.until+0:03.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until+0:03.raw z50c.skip10.until+0:03.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until+0:03.raw || die "ERROR: file mismatch for --skip=10 --until=+0:03 (encode)"
-rm -f z50c.skip10.until+0:03.flac z50c.skip10.until+0:03.raw
-echo OK
-
-echo -n "testing --skip=10 --until=+mm:ss.sss (encode)... "
-run_flac $eopt --skip=10 --until=+0:02.9001 -o z50c.skip10.until+0:02.9001.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until+0:02.9001.raw z50c.skip10.until+0:02.9001.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until39.raw z50c.skip10.until+0:02.9001.raw || die "ERROR: file mismatch for --skip=10 --until=+0:02.9001 (encode)"
-rm -f z50c.skip10.until+0:02.9001.flac z50c.skip10.until+0:02.9001.raw
-echo OK
-
-echo -n "testing --skip=10 --until=-# (encode)... "
-run_flac $eopt --skip=10 --until=-10 -o z50c.skip10.until-10.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until-10.raw z50c.skip10.until-10.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until-10.raw || die "ERROR: file mismatch for --skip=10 --until=-10 (encode)"
-rm -f z50c.skip10.until-10.flac z50c.skip10.until-10.raw
-echo OK
-
-echo -n "testing --skip=10 --until=-mm:ss (encode)... "
-run_flac $eopt --skip=10 --until=-0:01 -o z50c.skip10.until-0:01.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until-0:01.raw z50c.skip10.until-0:01.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until-0:01.raw || die "ERROR: file mismatch for --skip=10 --until=-0:01 (encode)"
-rm -f z50c.skip10.until-0:01.flac z50c.skip10.until-0:01.raw
-echo OK
-
-echo -n "testing --skip=10 --until=-mm:ss.sss (encode)... "
-run_flac $eopt --skip=10 --until=-0:01.1001 -o z50c.skip10.until-0:01.1001.flac 50c.raw || die "ERROR generating FLAC file"
-run_flac $dopt -o z50c.skip10.until-0:01.1001.raw z50c.skip10.until-0:01.1001.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until39.raw z50c.skip10.until-0:01.1001.raw || die "ERROR: file mismatch for --skip=10 --until=-0:01.1001 (encode)"
-rm -f z50c.skip10.until-0:01.1001.flac z50c.skip10.until-0:01.1001.raw
-echo OK
-
-#
-# test --skip and --until when decoding
-#
+       [ $fmt = wav ] || [ $fmt = aiff ] || [ $fmt = raw ] || die "ERROR: internal error, bad format '$fmt'"
 
-run_flac $eopt -o z50c.flac 50c.raw || die "ERROR generating FLAC file"
+       if [ $fmt = raw ] ; then
+               eopt="$raw_eopt"
+               dopt="$raw_dopt"
+       else
+               eopt="$wav_eopt"
+               dopt="$wav_dopt"
+       fi
 
-echo -n "testing --skip=10 --until=# (decode)... "
-run_flac $dopt --skip=10 --until=40 -o z50c.skip10.until40.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until40.raw || die "ERROR: file mismatch for --skip=10 --until=40 (decode)"
-rm -f z50c.skip10.until40.raw
-echo OK
+       #
+       # test --skip when encoding
+       #
+
+       echo -n "testing --skip=# (encode) ($fmt)... "
+       run_flac $eopt --skip=10 -o z50c.skip10.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.$fmt z50c.skip10.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.$fmt z50c.skip10.$fmt || die "ERROR: file mismatch for --skip=10 (encode) ($fmt)"
+       rm -f z50c.skip10.flac z50c.skip10.$fmt
+       echo OK
+
+       echo -n "testing --skip=mm:ss (encode) ($fmt)... "
+       run_flac $eopt --skip=0:01 -o z50c.skip0:01.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip0:01.$fmt z50c.skip0:01.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.$fmt z50c.skip0:01.$fmt || die "ERROR: file mismatch for --skip=0:01 (encode) ($fmt)"
+       rm -f z50c.skip0:01.flac z50c.skip0:01.$fmt
+       echo OK
+
+       echo -n "testing --skip=mm:ss.sss (encode) ($fmt)... "
+       run_flac $eopt --skip=0:01.1001 -o z50c.skip0:01.1001.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip0:01.1001.$fmt z50c.skip0:01.1001.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip11.$fmt z50c.skip0:01.1001.$fmt || die "ERROR: file mismatch for --skip=0:01.1001 (encode) ($fmt)"
+       rm -f z50c.skip0:01.1001.flac z50c.skip0:01.1001.$fmt
+       echo OK
+
+       #
+       # test --skip when decoding
+       #
+
+       echo -n "testing --skip=# (decode) ($fmt)... "
+       run_flac $eopt -o z50c.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt --skip=10 -o z50c.skip10.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.$fmt z50c.skip10.$fmt || die "ERROR: file mismatch for --skip=10 (decode) ($fmt)"
+       rm -f z50c.skip10.$fmt
+       echo OK
+
+       echo -n "testing --skip=mm:ss (decode) ($fmt)... "
+       run_flac $dopt --skip=0:01 -o z50c.skip0:01.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.$fmt z50c.skip0:01.$fmt || die "ERROR: file mismatch for --skip=0:01 (decode) ($fmt)"
+       rm -f z50c.skip0:01.$fmt
+       echo OK
+
+       echo -n "testing --skip=mm:ss.sss (decode) ($fmt)... "
+       run_flac $dopt --skip=0:01.1001 -o z50c.skip0:01.1001.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip11.$fmt z50c.skip0:01.1001.$fmt || die "ERROR: file mismatch for --skip=0:01.1001 (decode) ($fmt)"
+       rm -f z50c.skip0:01.1001.$fmt
+       echo OK
+
+       rm -f z50c.flac
+
+       #
+       # test --until when encoding
+       #
+
+       echo -n "testing --until=# (encode) ($fmt)... "
+       run_flac $eopt --until=40 -o z50c.until40.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.until40.$fmt z50c.until40.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until40.$fmt z50c.until40.$fmt || die "ERROR: file mismatch for --until=40 (encode) ($fmt)"
+       rm -f z50c.until40.flac z50c.until40.$fmt
+       echo OK
+
+       echo -n "testing --until=mm:ss (encode) ($fmt)... "
+       run_flac $eopt --until=0:04 -o z50c.until0:04.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.until0:04.$fmt z50c.until0:04.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until40.$fmt z50c.until0:04.$fmt || die "ERROR: file mismatch for --until=0:04 (encode) ($fmt)"
+       rm -f z50c.until0:04.flac z50c.until0:04.$fmt
+       echo OK
+
+       echo -n "testing --until=mm:ss.sss (encode) ($fmt)... "
+       run_flac $eopt --until=0:03.9001 -o z50c.until0:03.9001.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.until0:03.9001.$fmt z50c.until0:03.9001.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until39.$fmt z50c.until0:03.9001.$fmt || die "ERROR: file mismatch for --until=0:03.9001 (encode) ($fmt)"
+       rm -f z50c.until0:03.9001.flac z50c.until0:03.9001.$fmt
+       echo OK
+
+       echo -n "testing --until=-# (encode) ($fmt)... "
+       run_flac $eopt --until=-10 -o z50c.until-10.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.until-10.$fmt z50c.until-10.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until40.$fmt z50c.until-10.$fmt || die "ERROR: file mismatch for --until=-10 (encode) ($fmt)"
+       rm -f z50c.until-10.flac z50c.until-10.$fmt
+       echo OK
+
+       echo -n "testing --until=-mm:ss (encode) ($fmt)... "
+       run_flac $eopt --until=-0:01 -o z50c.until-0:01.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.until-0:01.$fmt z50c.until-0:01.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until40.$fmt z50c.until-0:01.$fmt || die "ERROR: file mismatch for --until=-0:01 (encode) ($fmt)"
+       rm -f z50c.until-0:01.flac z50c.until-0:01.$fmt
+       echo OK
+
+       echo -n "testing --until=-mm:ss.sss (encode) ($fmt)... "
+       run_flac $eopt --until=-0:01.1001 -o z50c.until-0:01.1001.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.until-0:01.1001.$fmt z50c.until-0:01.1001.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until39.$fmt z50c.until-0:01.1001.$fmt || die "ERROR: file mismatch for --until=-0:01.1001 (encode) ($fmt)"
+       rm -f z50c.until-0:01.1001.flac z50c.until-0:01.1001.$fmt
+       echo OK
+
+       #
+       # test --until when decoding
+       #
+
+       run_flac $eopt -o z50c.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+
+       echo -n "testing --until=# (decode) ($fmt)... "
+       run_flac $dopt --until=40 -o z50c.until40.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until40.$fmt z50c.until40.$fmt || die "ERROR: file mismatch for --until=40 (decode) ($fmt)"
+       rm -f z50c.until40.$fmt
+       echo OK
+
+       echo -n "testing --until=mm:ss (decode) ($fmt)... "
+       run_flac $dopt --until=0:04 -o z50c.until0:04.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until40.$fmt z50c.until0:04.$fmt || die "ERROR: file mismatch for --until=0:04 (decode) ($fmt)"
+       rm -f z50c.until0:04.$fmt
+       echo OK
+
+       echo -n "testing --until=mm:ss.sss (decode) ($fmt)... "
+       run_flac $dopt --until=0:03.9001 -o z50c.until0:03.9001.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until39.$fmt z50c.until0:03.9001.$fmt || die "ERROR: file mismatch for --until=0:03.9001 (decode) ($fmt)"
+       rm -f z50c.until0:03.9001.$fmt
+       echo OK
+
+       echo -n "testing --until=-# (decode) ($fmt)... "
+       run_flac $dopt --until=-10 -o z50c.until-10.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until40.$fmt z50c.until-10.$fmt || die "ERROR: file mismatch for --until=-10 (decode) ($fmt)"
+       rm -f z50c.until-10.$fmt
+       echo OK
+
+       echo -n "testing --until=-mm:ss (decode) ($fmt)... "
+       run_flac $dopt --until=-0:01 -o z50c.until-0:01.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until40.$fmt z50c.until-0:01.$fmt || die "ERROR: file mismatch for --until=-0:01 (decode) ($fmt)"
+       rm -f z50c.until-0:01.$fmt
+       echo OK
+
+       echo -n "testing --until=-mm:ss.sss (decode) ($fmt)... "
+       run_flac $dopt --until=-0:01.1001 -o z50c.until-0:01.1001.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.until39.$fmt z50c.until-0:01.1001.$fmt || die "ERROR: file mismatch for --until=-0:01.1001 (decode) ($fmt)"
+       rm -f z50c.until-0:01.1001.$fmt
+       echo OK
+
+       rm -f z50c.flac
+
+       #
+       # test --skip and --until when encoding
+       #
+
+       echo -n "testing --skip=10 --until=# (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=40 -o z50c.skip10.until40.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until40.$fmt z50c.skip10.until40.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until40.$fmt || die "ERROR: file mismatch for --skip=10 --until=40 (encode) ($fmt)"
+       rm -f z50c.skip10.until40.flac z50c.skip10.until40.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=mm:ss (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until0:04.$fmt z50c.skip10.until0:04.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until0:04.$fmt || die "ERROR: file mismatch for --skip=10 --until=0:04 (encode) ($fmt)"
+       rm -f z50c.skip10.until0:04.flac z50c.skip10.until0:04.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=mm:ss.sss (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=0:03.9001 -o z50c.skip10.until0:03.9001.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until0:03.9001.$fmt z50c.skip10.until0:03.9001.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until39.$fmt z50c.skip10.until0:03.9001.$fmt || die "ERROR: file mismatch for --skip=10 --until=0:03.9001 (encode) ($fmt)"
+       rm -f z50c.skip10.until0:03.9001.flac z50c.skip10.until0:03.9001.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=+# (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=+30 -o z50c.skip10.until+30.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until+30.$fmt z50c.skip10.until+30.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until+30.$fmt || die "ERROR: file mismatch for --skip=10 --until=+30 (encode) ($fmt)"
+       rm -f z50c.skip10.until+30.flac z50c.skip10.until+30.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=+mm:ss (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=+0:03 -o z50c.skip10.until+0:03.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until+0:03.$fmt z50c.skip10.until+0:03.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until+0:03.$fmt || die "ERROR: file mismatch for --skip=10 --until=+0:03 (encode) ($fmt)"
+       rm -f z50c.skip10.until+0:03.flac z50c.skip10.until+0:03.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=+mm:ss.sss (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=+0:02.9001 -o z50c.skip10.until+0:02.9001.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until+0:02.9001.$fmt z50c.skip10.until+0:02.9001.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until39.$fmt z50c.skip10.until+0:02.9001.$fmt || die "ERROR: file mismatch for --skip=10 --until=+0:02.9001 (encode) ($fmt)"
+       rm -f z50c.skip10.until+0:02.9001.flac z50c.skip10.until+0:02.9001.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=-# (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=-10 -o z50c.skip10.until-10.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until-10.$fmt z50c.skip10.until-10.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until-10.$fmt || die "ERROR: file mismatch for --skip=10 --until=-10 (encode) ($fmt)"
+       rm -f z50c.skip10.until-10.flac z50c.skip10.until-10.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=-mm:ss (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=-0:01 -o z50c.skip10.until-0:01.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until-0:01.$fmt z50c.skip10.until-0:01.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until-0:01.$fmt || die "ERROR: file mismatch for --skip=10 --until=-0:01 (encode) ($fmt)"
+       rm -f z50c.skip10.until-0:01.flac z50c.skip10.until-0:01.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=-mm:ss.sss (encode) ($fmt)... "
+       run_flac $eopt --skip=10 --until=-0:01.1001 -o z50c.skip10.until-0:01.1001.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+       run_flac $dopt -o z50c.skip10.until-0:01.1001.$fmt z50c.skip10.until-0:01.1001.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until39.$fmt z50c.skip10.until-0:01.1001.$fmt || die "ERROR: file mismatch for --skip=10 --until=-0:01.1001 (encode) ($fmt)"
+       rm -f z50c.skip10.until-0:01.1001.flac z50c.skip10.until-0:01.1001.$fmt
+       echo OK
+
+       #
+       # test --skip and --until when decoding
+       #
+
+       run_flac $eopt -o z50c.flac 50c.$fmt || die "ERROR generating FLAC file ($fmt)"
+
+       echo -n "testing --skip=10 --until=# (decode) ($fmt)... "
+       run_flac $dopt --skip=10 --until=40 -o z50c.skip10.until40.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until40.$fmt || die "ERROR: file mismatch for --skip=10 --until=40 (decode) ($fmt)"
+       rm -f z50c.skip10.until40.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=mm:ss (decode) ($fmt)... "
+       run_flac $dopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until0:04.$fmt || die "ERROR: file mismatch for --skip=10 --until=0:04 (decode) ($fmt)"
+       rm -f z50c.skip10.until0:04.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=mm:ss.sss (decode) ($fmt)... "
+       run_flac $dopt --skip=10 --until=0:03.9001 -o z50c.skip10.until0:03.9001.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until39.$fmt z50c.skip10.until0:03.9001.$fmt || die "ERROR: file mismatch for --skip=10 --until=0:03.9001 (decode) ($fmt)"
+       rm -f z50c.skip10.until0:03.9001.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=-# (decode) ($fmt)... "
+       run_flac $dopt --skip=10 --until=-10 -o z50c.skip10.until-10.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until-10.$fmt || die "ERROR: file mismatch for --skip=10 --until=-10 (decode) ($fmt)"
+       rm -f z50c.skip10.until-10.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=-mm:ss (decode) ($fmt)... "
+       run_flac $dopt --skip=10 --until=-0:01 -o z50c.skip10.until-0:01.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until40.$fmt z50c.skip10.until-0:01.$fmt || die "ERROR: file mismatch for --skip=10 --until=-0:01 (decode) ($fmt)"
+       rm -f z50c.skip10.until-0:01.$fmt
+       echo OK
+
+       echo -n "testing --skip=10 --until=-mm:ss.sss (decode) ($fmt)... "
+       run_flac $dopt --skip=10 --until=-0:01.1001 -o z50c.skip10.until-0:01.1001.$fmt z50c.flac || die "ERROR decoding FLAC file ($fmt)"
+       cmp 50c.skip10.until39.$fmt z50c.skip10.until-0:01.1001.$fmt || die "ERROR: file mismatch for --skip=10 --until=-0:01.1001 (decode) ($fmt)"
+       rm -f z50c.skip10.until-0:01.1001.$fmt
+       echo OK
+
+       rm -f z50c.flac
+}
 
-echo -n "testing --skip=10 --until=mm:ss (decode)... "
-run_flac $dopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until0:04.raw || die "ERROR: file mismatch for --skip=10 --until=0:04 (decode)"
-rm -f z50c.skip10.until0:04.raw
-echo OK
+test_skip_until raw
+test_skip_until wav
+test_skip_until aiff
 
-echo -n "testing --skip=10 --until=mm:ss.sss (decode)... "
-run_flac $dopt --skip=10 --until=0:03.9001 -o z50c.skip10.until0:03.9001.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until39.raw z50c.skip10.until0:03.9001.raw || die "ERROR: file mismatch for --skip=10 --until=0:03.9001 (decode)"
-rm -f z50c.skip10.until0:03.9001.raw
-echo OK
 
-echo -n "testing --skip=10 --until=-# (decode)... "
-run_flac $dopt --skip=10 --until=-10 -o z50c.skip10.until-10.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until-10.raw || die "ERROR: file mismatch for --skip=10 --until=-10 (decode)"
-rm -f z50c.skip10.until-10.raw
-echo OK
+############################################################################
+# test 'fixup' code that happens when a FLAC file with total_samples == 0
+# in the STREAMINFO block is converted to WAVE or AIFF, requiring the
+# decoder go back and fix up the chunk headers
+############################################################################
 
-echo -n "testing --skip=10 --until=-mm:ss (decode)... "
-run_flac $dopt --skip=10 --until=-0:01 -o z50c.skip10.until-0:01.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until40.raw z50c.skip10.until-0:01.raw || die "ERROR: file mismatch for --skip=10 --until=-0:01 (decode)"
-rm -f z50c.skip10.until-0:01.raw
+echo -n "WAVE fixup test... "
+echo -n "prepare... "
+convert_to_wav noise || die "ERROR creating reference WAVE"
+echo -n "encode... "
+cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
+echo -n "decode... "
+run_flac $wav_dopt fixup.flac -o fixup.wav || die "ERROR decoding FLAC file"
+echo -n "compare... "
+cmp noise.wav fixup.wav || die "ERROR: file mismatch"
 echo OK
+rm -f noise.wav fixup.wav fixup.flac
 
-echo -n "testing --skip=10 --until=-mm:ss.sss (decode)... "
-run_flac $dopt --skip=10 --until=-0:01.1001 -o z50c.skip10.until-0:01.1001.raw z50c.flac || die "ERROR decoding FLAC file"
-cmp 50c.skip10.until39.raw z50c.skip10.until-0:01.1001.raw || die "ERROR: file mismatch for --skip=10 --until=-0:01.1001 (decode)"
-rm -f z50c.skip10.until-0:01.1001.raw
+echo -n "AIFF fixup test... "
+echo -n "prepare... "
+convert_to_aiff noise || die "ERROR creating reference AIFF"
+echo -n "encode... "
+cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
+echo -n "decode... "
+run_flac $wav_dopt fixup.flac -o fixup.aiff || die "ERROR decoding FLAC file"
+echo -n "compare... "
+cmp noise.aiff fixup.aiff || die "ERROR: file mismatch"
 echo OK
+rm -f noise.aiff fixup.aiff fixup.flac
 
-rm -f z50c.flac
 
-#@@@@@@
-exit 123
-
-#
+############################################################################
 # multi-file tests
-#
-
-echo "Generating streams..."
-if [ ! -f wacky1.wav ] ; then
-       test_streams || die "ERROR during test_streams"
-fi
+############################################################################
 
 echo "Generating multiple input files from noise..."
 run_flac --verify --silent --force-raw-format --endian=big --sign=signed --sample-rate=44100 --bps=16 --channels=2 noise.raw || die "ERROR generating FLAC file"