annotate src/flac-1.2.1/test/test_flac.sh @ 23:619f715526df sv_v2.1

Update Vamp plugin SDK to 2.5
author Chris Cannam
date Thu, 09 May 2013 10:52:46 +0100
parents 05aa0afa9217
children
rev   line source
Chris@1 1 #!/bin/sh
Chris@1 2
Chris@1 3 # FLAC - Free Lossless Audio Codec
Chris@1 4 # Copyright (C) 2001,2002,2003,2004,2005,2006,2007 Josh Coalson
Chris@1 5 #
Chris@1 6 # This file is part the FLAC project. FLAC is comprised of several
Chris@1 7 # components distributed under difference licenses. The codec libraries
Chris@1 8 # are distributed under Xiph.Org's BSD-like license (see the file
Chris@1 9 # COPYING.Xiph in this distribution). All other programs, libraries, and
Chris@1 10 # plugins are distributed under the GPL (see COPYING.GPL). The documentation
Chris@1 11 # is distributed under the Gnu FDL (see COPYING.FDL). Each file in the
Chris@1 12 # FLAC distribution contains at the top the terms under which it may be
Chris@1 13 # distributed.
Chris@1 14 #
Chris@1 15 # Since this particular file is relevant to all components of FLAC,
Chris@1 16 # it may be distributed under the Xiph.Org license, which is the least
Chris@1 17 # restrictive of those mentioned above. See the file COPYING.Xiph in this
Chris@1 18 # distribution.
Chris@1 19
Chris@1 20 die ()
Chris@1 21 {
Chris@1 22 echo $* 1>&2
Chris@1 23 exit 1
Chris@1 24 }
Chris@1 25
Chris@1 26 dddie="die ERROR: creating files with dd"
Chris@1 27
Chris@1 28 if [ x = x"$1" ] ; then
Chris@1 29 BUILD=debug
Chris@1 30 else
Chris@1 31 BUILD="$1"
Chris@1 32 fi
Chris@1 33
Chris@1 34 # change to 'false' to show flac output (useful for debugging)
Chris@1 35 if true ; then
Chris@1 36 SILENT='--silent'
Chris@1 37 TOTALLY_SILENT='--totally-silent'
Chris@1 38 else
Chris@1 39 SILENT=''
Chris@1 40 TOTALLY_SILENT=''
Chris@1 41 fi
Chris@1 42
Chris@1 43 LD_LIBRARY_PATH=`pwd`/../src/libFLAC/.libs:$LD_LIBRARY_PATH
Chris@1 44 LD_LIBRARY_PATH=`pwd`/../src/share/grabbag/.libs:$LD_LIBRARY_PATH
Chris@1 45 LD_LIBRARY_PATH=`pwd`/../src/share/getopt/.libs:$LD_LIBRARY_PATH
Chris@1 46 LD_LIBRARY_PATH=`pwd`/../src/share/replaygain_analysis/.libs:$LD_LIBRARY_PATH
Chris@1 47 LD_LIBRARY_PATH=`pwd`/../src/share/replaygain_synthesis/.libs:$LD_LIBRARY_PATH
Chris@1 48 LD_LIBRARY_PATH=`pwd`/../src/share/utf8/.libs:$LD_LIBRARY_PATH
Chris@1 49 LD_LIBRARY_PATH=`pwd`/../obj/$BUILD/lib:$LD_LIBRARY_PATH
Chris@1 50 export LD_LIBRARY_PATH
Chris@1 51 PATH=`pwd`/../src/flac:$PATH
Chris@1 52 PATH=`pwd`/../src/metaflac:$PATH
Chris@1 53 PATH=`pwd`/../src/test_streams:$PATH
Chris@1 54 PATH=`pwd`/../obj/$BUILD/bin:$PATH
Chris@1 55
Chris@1 56 flac --help 1>/dev/null 2>/dev/null || die "ERROR can't find flac executable"
Chris@1 57
Chris@1 58 run_flac ()
Chris@1 59 {
Chris@1 60 if [ x"$FLAC__TEST_WITH_VALGRIND" = xyes ] ; then
Chris@1 61 echo "valgrind --leak-check=yes --show-reachable=yes --num-callers=100 flac $*" >>test_flac.valgrind.log
Chris@1 62 valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --log-fd=4 flac $* 4>>test_flac.valgrind.log
Chris@1 63 else
Chris@1 64 flac $*
Chris@1 65 fi
Chris@1 66 }
Chris@1 67
Chris@1 68 run_metaflac ()
Chris@1 69 {
Chris@1 70 if [ x"$FLAC__TEST_WITH_VALGRIND" = xyes ] ; then
Chris@1 71 echo "valgrind --leak-check=yes --show-reachable=yes --num-callers=100 metaflac $*" >>test_flac.valgrind.log
Chris@1 72 valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --log-fd=4 metaflac $* 4>>test_flac.valgrind.log
Chris@1 73 else
Chris@1 74 metaflac $*
Chris@1 75 fi
Chris@1 76 }
Chris@1 77
Chris@1 78 md5cmp ()
Chris@1 79 {
Chris@1 80 #n=`( [ -f "$1" ] && [ -f "$2" ] && metaflac --show-md5sum --no-filename "$1" "$2" 2>/dev/null || die "ERROR: comparing FLAC files $1 and $2 by MD5 sum" ) | uniq | wc -l`
Chris@1 81 n=`( [ -f "$1" ] && [ -f "$2" ] && metaflac --show-md5sum --no-filename "$1" "$2" 2>/dev/null || exit 1 ) | uniq | wc -l`
Chris@1 82 [ "$n" != "" ] && [ $n = 1 ]
Chris@1 83 }
Chris@1 84
Chris@1 85 if [ `env | grep -ic '^comspec='` != 0 ] ; then
Chris@1 86 is_win=yes
Chris@1 87 else
Chris@1 88 is_win=no
Chris@1 89 fi
Chris@1 90
Chris@1 91 echo "Checking for --ogg support in flac..."
Chris@1 92 if 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
Chris@1 93 has_ogg=yes;
Chris@1 94 echo "flac --ogg works"
Chris@1 95 else
Chris@1 96 has_ogg=no;
Chris@1 97 echo "flac --ogg doesn't work"
Chris@1 98 fi
Chris@1 99
Chris@1 100 echo "Generating streams..."
Chris@1 101 if [ ! -f wacky1.wav ] ; then
Chris@1 102 test_streams || die "ERROR during test_streams"
Chris@1 103 fi
Chris@1 104
Chris@1 105 ############################################################################
Chris@1 106 # test that flac doesn't automatically overwrite files unless -f is used
Chris@1 107 ############################################################################
Chris@1 108
Chris@1 109 echo "Try encoding to a file that exists; should fail"
Chris@1 110 cp wacky1.wav exist.wav
Chris@1 111 touch exist.flac
Chris@1 112 if run_flac $TOTALLY_SILENT -0 exist.wav ; then
Chris@1 113 die "ERROR: it should have failed but didn't"
Chris@1 114 else
Chris@1 115 echo "OK, it failed as it should"
Chris@1 116 fi
Chris@1 117
Chris@1 118 echo "Try encoding with -f to a file that exists; should succeed"
Chris@1 119 if run_flac $TOTALLY_SILENT -0 --force exist.wav ; then
Chris@1 120 echo "OK, it succeeded as it should"
Chris@1 121 else
Chris@1 122 die "ERROR: it should have succeeded but didn't"
Chris@1 123 fi
Chris@1 124
Chris@1 125 echo "Try decoding to a file that exists; should fail"
Chris@1 126 if run_flac $TOTALLY_SILENT -d exist.flac ; then
Chris@1 127 die "ERROR: it should have failed but didn't"
Chris@1 128 else
Chris@1 129 echo "OK, it failed as it should"
Chris@1 130 fi
Chris@1 131
Chris@1 132 echo "Try decoding with -f to a file that exists; should succeed"
Chris@1 133 if run_flac $TOTALLY_SILENT -d -f exist.flac ; then
Chris@1 134 echo "OK, it succeeded as it should"
Chris@1 135 else
Chris@1 136 die "ERROR: it should have succeeded but didn't"
Chris@1 137 fi
Chris@1 138
Chris@1 139 rm -f exist.wav exist.flac
Chris@1 140
Chris@1 141 ############################################################################
Chris@1 142 # test fractional block sizes
Chris@1 143 ############################################################################
Chris@1 144
Chris@1 145 test_fractional ()
Chris@1 146 {
Chris@1 147 blocksize=$1
Chris@1 148 samples=$2
Chris@1 149 dd if=noise.raw ibs=4 count=$samples of=pbs.raw 2>/dev/null || $dddie
Chris@1 150 echo -n "fractional block size test (blocksize=$blocksize samples=$samples) encode... "
Chris@1 151 run_flac $SILENT --force --verify --force-raw-format --endian=little --sign=signed --sample-rate=44100 --bps=16 --channels=2 --blocksize=$blocksize --no-padding --lax -o pbs.flac pbs.raw || die "ERROR"
Chris@1 152 echo -n "decode... "
Chris@1 153 run_flac $SILENT --force --decode --force-raw-format --endian=little --sign=signed -o pbs.cmp pbs.flac || die "ERROR"
Chris@1 154 echo -n "compare... "
Chris@1 155 cmp pbs.raw pbs.cmp || die "ERROR: file mismatch"
Chris@1 156 echo "OK"
Chris@1 157 rm -f pbs.raw pbs.flac pbs.cmp
Chris@1 158 }
Chris@1 159
Chris@1 160 # The special significance of 2048 is it's the # of samples that flac calls
Chris@1 161 # FLAC__stream_encoder_process() on.
Chris@1 162 #
Chris@1 163 # We're trying to make sure the 1-sample overread logic in the stream encoder
Chris@1 164 # (used for last-block checking) works; these values probe around common
Chris@1 165 # multiples of the flac sample chunk size (2048) and the blocksize.
Chris@1 166 for samples in 31 32 33 34 35 2046 2047 2048 2049 2050 ; do
Chris@1 167 test_fractional 33 $samples
Chris@1 168 done
Chris@1 169 for samples in 254 255 256 257 258 510 511 512 513 514 1022 1023 1024 1025 1026 2046 2047 2048 2049 2050 4094 4095 4096 4097 4098 ; do
Chris@1 170 test_fractional 256 $samples
Chris@1 171 done
Chris@1 172 for samples in 1022 1023 1024 1025 1026 2046 2047 2048 2049 2050 4094 4095 4096 4097 4098 ; do
Chris@1 173 test_fractional 2048 $samples
Chris@1 174 done
Chris@1 175 for samples in 1022 1023 1024 1025 1026 2046 2047 2048 2049 2050 4094 4095 4096 4097 4098 4606 4607 4608 4609 4610 8190 8191 8192 8193 8194 16382 16383 16384 16385 16386 ; do
Chris@1 176 test_fractional 4608 $samples
Chris@1 177 done
Chris@1 178
Chris@1 179 ############################################################################
Chris@1 180 # basic 'round-trip' tests of various kinds of streams
Chris@1 181 ############################################################################
Chris@1 182
Chris@1 183 rt_test_raw ()
Chris@1 184 {
Chris@1 185 f="$1"
Chris@1 186 channels=`echo $f | awk -F- '{print $2}'`
Chris@1 187 bps=`echo $f | awk -F- '{print $3}'`
Chris@1 188 echo -n "round-trip test ($f) encode... "
Chris@1 189 run_flac $SILENT --force --verify --force-raw-format --endian=little --sign=signed --sample-rate=44100 --bps=$bps --channels=$channels --no-padding --lax -o rt.flac $f || die "ERROR"
Chris@1 190 echo -n "decode... "
Chris@1 191 run_flac $SILENT --force --decode --force-raw-format --endian=little --sign=signed -o rt.raw rt.flac || die "ERROR"
Chris@1 192 echo -n "compare... "
Chris@1 193 cmp $f rt.raw || die "ERROR: file mismatch"
Chris@1 194 echo "OK"
Chris@1 195 rm -f rt.flac rt.raw
Chris@1 196 }
Chris@1 197
Chris@1 198 rt_test_wav ()
Chris@1 199 {
Chris@1 200 f="$1"
Chris@1 201 echo -n "round-trip test ($f) encode... "
Chris@1 202 run_flac $SILENT --force --verify --channel-map=none --no-padding --lax -o rt.flac $f || die "ERROR"
Chris@1 203 echo -n "decode... "
Chris@1 204 run_flac $SILENT --force --decode --channel-map=none -o rt.wav rt.flac || die "ERROR"
Chris@1 205 echo -n "compare... "
Chris@1 206 cmp $f rt.wav || die "ERROR: file mismatch"
Chris@1 207 echo "OK"
Chris@1 208 rm -f rt.flac rt.wav
Chris@1 209 }
Chris@1 210
Chris@1 211 rt_test_aiff ()
Chris@1 212 {
Chris@1 213 f="$1"
Chris@1 214 echo -n "round-trip test ($f) encode... "
Chris@1 215 run_flac $SILENT --force --verify --channel-map=none --no-padding --lax -o rt.flac $f || die "ERROR"
Chris@1 216 echo -n "decode... "
Chris@1 217 run_flac $SILENT --force --decode --channel-map=none -o rt.aiff rt.flac || die "ERROR"
Chris@1 218 echo -n "compare... "
Chris@1 219 cmp $f rt.aiff || die "ERROR: file mismatch"
Chris@1 220 echo "OK"
Chris@1 221 rm -f rt.flac rt.aiff
Chris@1 222 }
Chris@1 223
Chris@1 224 # assumes input file is WAVE; does not check the metadata-preserving features of flac-to-flac; that is checked later
Chris@1 225 rt_test_flac ()
Chris@1 226 {
Chris@1 227 f="$1"
Chris@1 228 echo -n "round-trip test ($f->flac->flac->wav) encode... "
Chris@1 229 run_flac $SILENT --force --verify --channel-map=none --no-padding --lax -o rt.flac $f || die "ERROR"
Chris@1 230 echo -n "re-encode... "
Chris@1 231 run_flac $SILENT --force --verify --lax -o rt2.flac rt.flac || die "ERROR"
Chris@1 232 echo -n "decode... "
Chris@1 233 run_flac $SILENT --force --decode --channel-map=none -o rt.wav rt2.flac || die "ERROR"
Chris@1 234 echo -n "compare... "
Chris@1 235 cmp $f rt.wav || die "ERROR: file mismatch"
Chris@1 236 echo "OK"
Chris@1 237 rm -f rt.wav rt.flac rt2.flac
Chris@1 238 }
Chris@1 239
Chris@1 240 # assumes input file is WAVE; does not check the metadata-preserving features of flac-to-flac; that is checked later
Chris@1 241 rt_test_ogg_flac ()
Chris@1 242 {
Chris@1 243 f="$1"
Chris@1 244 echo -n "round-trip test ($f->oggflac->oggflac->wav) encode... "
Chris@1 245 run_flac $SILENT --force --verify --channel-map=none --no-padding --lax -o rt.oga --ogg $f || die "ERROR"
Chris@1 246 echo -n "re-encode... "
Chris@1 247 run_flac $SILENT --force --verify --lax -o rt2.oga --ogg rt.oga || die "ERROR"
Chris@1 248 echo -n "decode... "
Chris@1 249 run_flac $SILENT --force --decode --channel-map=none -o rt.wav rt2.oga || die "ERROR"
Chris@1 250 echo -n "compare... "
Chris@1 251 cmp $f rt.wav || die "ERROR: file mismatch"
Chris@1 252 echo "OK"
Chris@1 253 rm -f rt.wav rt.oga rt2.oga
Chris@1 254 }
Chris@1 255
Chris@1 256 for f in rt-*.raw ; do
Chris@1 257 rt_test_raw $f
Chris@1 258 done
Chris@1 259 for f in rt-*.wav ; do
Chris@1 260 rt_test_wav $f
Chris@1 261 done
Chris@1 262 for f in rt-*.aiff ; do
Chris@1 263 rt_test_aiff $f
Chris@1 264 done
Chris@1 265 for f in rt-*.wav ; do
Chris@1 266 rt_test_flac $f
Chris@1 267 done
Chris@1 268 if [ $has_ogg = yes ] ; then
Chris@1 269 for f in rt-*.wav ; do
Chris@1 270 rt_test_ogg_flac $f
Chris@1 271 done
Chris@1 272 fi
Chris@1 273
Chris@1 274 ############################################################################
Chris@1 275 # test --skip and --until
Chris@1 276 ############################################################################
Chris@1 277
Chris@1 278 #
Chris@1 279 # first make some chopped-up raw files
Chris@1 280 #
Chris@1 281 echo "abcdefghijklmnopqrstuvwxyz1234567890ABCDEFGHIJKLMN" > master.raw
Chris@1 282 dd if=master.raw ibs=1 count=50 of=50c.raw 2>/dev/null || $dddie
Chris@1 283 dd if=master.raw ibs=1 skip=10 count=40 of=50c.skip10.raw 2>/dev/null || $dddie
Chris@1 284 dd if=master.raw ibs=1 skip=11 count=39 of=50c.skip11.raw 2>/dev/null || $dddie
Chris@1 285 dd if=master.raw ibs=1 skip=20 count=30 of=50c.skip20.raw 2>/dev/null || $dddie
Chris@1 286 dd if=master.raw ibs=1 skip=30 count=20 of=50c.skip30.raw 2>/dev/null || $dddie
Chris@1 287 dd if=master.raw ibs=1 skip=40 count=10 of=50c.skip40.raw 2>/dev/null || $dddie
Chris@1 288 dd if=master.raw ibs=1 count=10 of=50c.until10.raw 2>/dev/null || $dddie
Chris@1 289 dd if=master.raw ibs=1 count=20 of=50c.until20.raw 2>/dev/null || $dddie
Chris@1 290 dd if=master.raw ibs=1 count=30 of=50c.until30.raw 2>/dev/null || $dddie
Chris@1 291 dd if=master.raw ibs=1 count=39 of=50c.until39.raw 2>/dev/null || $dddie
Chris@1 292 dd if=master.raw ibs=1 count=40 of=50c.until40.raw 2>/dev/null || $dddie
Chris@1 293 dd if=master.raw ibs=1 skip=10 count=20 of=50c.skip10.until30.raw 2>/dev/null || $dddie
Chris@1 294 dd if=master.raw ibs=1 skip=10 count=29 of=50c.skip10.until39.raw 2>/dev/null || $dddie
Chris@1 295 dd if=master.raw ibs=1 skip=10 count=30 of=50c.skip10.until40.raw 2>/dev/null || $dddie
Chris@1 296 dd if=master.raw ibs=1 skip=20 count=10 of=50c.skip20.until30.raw 2>/dev/null || $dddie
Chris@1 297 dd if=master.raw ibs=1 skip=20 count=20 of=50c.skip20.until40.raw 2>/dev/null || $dddie
Chris@1 298
Chris@1 299 wav_eopt="$SILENT --force --verify --no-padding --lax"
Chris@1 300 wav_dopt="$SILENT --force --decode"
Chris@1 301
Chris@1 302 raw_eopt="$wav_eopt --force-raw-format --endian=big --sign=signed --sample-rate=10 --bps=8 --channels=1"
Chris@1 303 raw_dopt="$wav_dopt --force-raw-format --endian=big --sign=signed"
Chris@1 304
Chris@1 305 #
Chris@1 306 # convert them to WAVE/AIFF/Ogg FLAC files
Chris@1 307 #
Chris@1 308 convert_to_wav ()
Chris@1 309 {
Chris@1 310 run_flac "$2" $1.raw || die "ERROR converting $1.raw to WAVE"
Chris@1 311 run_flac "$3" $1.flac || die "ERROR converting $1.raw to WAVE"
Chris@1 312 }
Chris@1 313 convert_to_wav 50c "$raw_eopt" "$wav_dopt"
Chris@1 314 convert_to_wav 50c.skip10 "$raw_eopt" "$wav_dopt"
Chris@1 315 convert_to_wav 50c.skip11 "$raw_eopt" "$wav_dopt"
Chris@1 316 convert_to_wav 50c.skip20 "$raw_eopt" "$wav_dopt"
Chris@1 317 convert_to_wav 50c.skip30 "$raw_eopt" "$wav_dopt"
Chris@1 318 convert_to_wav 50c.skip40 "$raw_eopt" "$wav_dopt"
Chris@1 319 convert_to_wav 50c.until10 "$raw_eopt" "$wav_dopt"
Chris@1 320 convert_to_wav 50c.until20 "$raw_eopt" "$wav_dopt"
Chris@1 321 convert_to_wav 50c.until30 "$raw_eopt" "$wav_dopt"
Chris@1 322 convert_to_wav 50c.until39 "$raw_eopt" "$wav_dopt"
Chris@1 323 convert_to_wav 50c.until40 "$raw_eopt" "$wav_dopt"
Chris@1 324 convert_to_wav 50c.skip10.until30 "$raw_eopt" "$wav_dopt"
Chris@1 325 convert_to_wav 50c.skip10.until39 "$raw_eopt" "$wav_dopt"
Chris@1 326 convert_to_wav 50c.skip10.until40 "$raw_eopt" "$wav_dopt"
Chris@1 327 convert_to_wav 50c.skip20.until30 "$raw_eopt" "$wav_dopt"
Chris@1 328 convert_to_wav 50c.skip20.until40 "$raw_eopt" "$wav_dopt"
Chris@1 329
Chris@1 330 convert_to_aiff ()
Chris@1 331 {
Chris@1 332 run_flac "$2" $1.raw || die "ERROR converting $1.raw to AIFF"
Chris@1 333 run_flac "$3" $1.flac -o $1.aiff || die "ERROR converting $1.raw to AIFF"
Chris@1 334 }
Chris@1 335 convert_to_aiff 50c "$raw_eopt" "$wav_dopt"
Chris@1 336 convert_to_aiff 50c.skip10 "$raw_eopt" "$wav_dopt"
Chris@1 337 convert_to_aiff 50c.skip11 "$raw_eopt" "$wav_dopt"
Chris@1 338 convert_to_aiff 50c.skip20 "$raw_eopt" "$wav_dopt"
Chris@1 339 convert_to_aiff 50c.skip30 "$raw_eopt" "$wav_dopt"
Chris@1 340 convert_to_aiff 50c.skip40 "$raw_eopt" "$wav_dopt"
Chris@1 341 convert_to_aiff 50c.until10 "$raw_eopt" "$wav_dopt"
Chris@1 342 convert_to_aiff 50c.until20 "$raw_eopt" "$wav_dopt"
Chris@1 343 convert_to_aiff 50c.until30 "$raw_eopt" "$wav_dopt"
Chris@1 344 convert_to_aiff 50c.until39 "$raw_eopt" "$wav_dopt"
Chris@1 345 convert_to_aiff 50c.until40 "$raw_eopt" "$wav_dopt"
Chris@1 346 convert_to_aiff 50c.skip10.until30 "$raw_eopt" "$wav_dopt"
Chris@1 347 convert_to_aiff 50c.skip10.until39 "$raw_eopt" "$wav_dopt"
Chris@1 348 convert_to_aiff 50c.skip10.until40 "$raw_eopt" "$wav_dopt"
Chris@1 349 convert_to_aiff 50c.skip20.until30 "$raw_eopt" "$wav_dopt"
Chris@1 350 convert_to_aiff 50c.skip20.until40 "$raw_eopt" "$wav_dopt"
Chris@1 351
Chris@1 352 convert_to_ogg ()
Chris@1 353 {
Chris@1 354 run_flac "$wav_eopt" --ogg $1.wav || die "ERROR converting $1.raw to Ogg FLAC"
Chris@1 355 }
Chris@1 356 if [ $has_ogg = yes ] ; then
Chris@1 357 convert_to_ogg 50c
Chris@1 358 convert_to_ogg 50c.skip10
Chris@1 359 convert_to_ogg 50c.skip11
Chris@1 360 convert_to_ogg 50c.skip20
Chris@1 361 convert_to_ogg 50c.skip30
Chris@1 362 convert_to_ogg 50c.skip40
Chris@1 363 convert_to_ogg 50c.until10
Chris@1 364 convert_to_ogg 50c.until20
Chris@1 365 convert_to_ogg 50c.until30
Chris@1 366 convert_to_ogg 50c.until39
Chris@1 367 convert_to_ogg 50c.until40
Chris@1 368 convert_to_ogg 50c.skip10.until30
Chris@1 369 convert_to_ogg 50c.skip10.until39
Chris@1 370 convert_to_ogg 50c.skip10.until40
Chris@1 371 convert_to_ogg 50c.skip20.until30
Chris@1 372 convert_to_ogg 50c.skip20.until40
Chris@1 373 fi
Chris@1 374
Chris@1 375 test_skip_until ()
Chris@1 376 {
Chris@1 377 in_fmt=$1
Chris@1 378 out_fmt=$2
Chris@1 379
Chris@1 380 [ "$in_fmt" = wav ] || [ "$in_fmt" = aiff ] || [ "$in_fmt" = raw ] || [ "$in_fmt" = flac ] || [ "$in_fmt" = ogg ] || die "ERROR: internal error, bad 'in' format '$in_fmt'"
Chris@1 381
Chris@1 382 [ "$out_fmt" = flac ] || [ "$out_fmt" = ogg ] || die "ERROR: internal error, bad 'out' format '$out_fmt'"
Chris@1 383
Chris@1 384 if [ $in_fmt = raw ] ; then
Chris@1 385 eopt="$raw_eopt"
Chris@1 386 dopt="$raw_dopt"
Chris@1 387 else
Chris@1 388 eopt="$wav_eopt"
Chris@1 389 dopt="$wav_dopt"
Chris@1 390 fi
Chris@1 391
Chris@1 392 if ( [ $in_fmt = flac ] || [ $in_fmt = ogg ] ) && ( [ $out_fmt = flac ] || [ $out_fmt = ogg ] ) ; then
Chris@1 393 CMP=md5cmp
Chris@1 394 else
Chris@1 395 CMP=cmp
Chris@1 396 fi
Chris@1 397
Chris@1 398 if [ $out_fmt = ogg ] ; then
Chris@1 399 eopt="--ogg $eopt"
Chris@1 400 fi
Chris@1 401
Chris@1 402 #
Chris@1 403 # test --skip when encoding
Chris@1 404 #
Chris@1 405
Chris@1 406 desc="($in_fmt<->$out_fmt)"
Chris@1 407
Chris@1 408 echo -n "testing --skip=# (encode) $desc... "
Chris@1 409 run_flac $eopt --skip=10 -o z50c.skip10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 410 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip10.$in_fmt z50c.skip10.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 411 $CMP 50c.skip10.$in_fmt z50c.skip10.$in_fmt || die "ERROR: file mismatch for --skip=10 (encode) $desc"
Chris@1 412 rm -f z50c.skip10.$out_fmt z50c.skip10.$in_fmt
Chris@1 413 echo OK
Chris@1 414
Chris@1 415 echo -n "testing --skip=mm:ss (encode) $desc... "
Chris@1 416 run_flac $eopt --skip=0:01 -o z50c.skip0:01.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 417 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip0:01.$in_fmt z50c.skip0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 418 $CMP 50c.skip10.$in_fmt z50c.skip0:01.$in_fmt || die "ERROR: file mismatch for --skip=0:01 (encode) $desc"
Chris@1 419 rm -f z50c.skip0:01.$out_fmt z50c.skip0:01.$in_fmt
Chris@1 420 echo OK
Chris@1 421
Chris@1 422 echo -n "testing --skip=mm:ss.sss (encode) $desc... "
Chris@1 423 run_flac $eopt --skip=0:01.1001 -o z50c.skip0:01.1001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 424 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip0:01.1001.$in_fmt z50c.skip0:01.1001.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 425 $CMP 50c.skip11.$in_fmt z50c.skip0:01.1001.$in_fmt || die "ERROR: file mismatch for --skip=0:01.1001 (encode) $desc"
Chris@1 426 rm -f z50c.skip0:01.1001.$out_fmt z50c.skip0:01.1001.$in_fmt
Chris@1 427 echo OK
Chris@1 428
Chris@1 429 #
Chris@1 430 # test --skip when decoding
Chris@1 431 #
Chris@1 432
Chris@1 433 if [ $in_fmt != $out_fmt ] ; then run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt ; else cp -f 50c.$in_fmt z50c.$out_fmt ; fi || die "ERROR generating FLAC file $desc"
Chris@1 434
Chris@1 435 echo -n "testing --skip=# (decode) $desc... "
Chris@1 436 run_flac $dopt --skip=10 -o z50c.skip10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 437 $CMP 50c.skip10.$in_fmt z50c.skip10.$in_fmt || die "ERROR: file mismatch for --skip=10 (decode) $desc"
Chris@1 438 rm -f z50c.skip10.$in_fmt
Chris@1 439 echo OK
Chris@1 440
Chris@1 441 echo -n "testing --skip=mm:ss (decode) $desc... "
Chris@1 442 run_flac $dopt --skip=0:01 -o z50c.skip0:01.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 443 $CMP 50c.skip10.$in_fmt z50c.skip0:01.$in_fmt || die "ERROR: file mismatch for --skip=0:01 (decode) $desc"
Chris@1 444 rm -f z50c.skip0:01.$in_fmt
Chris@1 445 echo OK
Chris@1 446
Chris@1 447 echo -n "testing --skip=mm:ss.sss (decode) $desc... "
Chris@1 448 run_flac $dopt --skip=0:01.1001 -o z50c.skip0:01.1001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 449 $CMP 50c.skip11.$in_fmt z50c.skip0:01.1001.$in_fmt || die "ERROR: file mismatch for --skip=0:01.1001 (decode) $desc"
Chris@1 450 rm -f z50c.skip0:01.1001.$in_fmt
Chris@1 451 echo OK
Chris@1 452
Chris@1 453 rm -f z50c.$out_fmt
Chris@1 454
Chris@1 455 #
Chris@1 456 # test --until when encoding
Chris@1 457 #
Chris@1 458
Chris@1 459 echo -n "testing --until=# (encode) $desc... "
Chris@1 460 run_flac $eopt --until=40 -o z50c.until40.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 461 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.until40.$in_fmt z50c.until40.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 462 $CMP 50c.until40.$in_fmt z50c.until40.$in_fmt || die "ERROR: file mismatch for --until=40 (encode) $desc"
Chris@1 463 rm -f z50c.until40.$out_fmt z50c.until40.$in_fmt
Chris@1 464 echo OK
Chris@1 465
Chris@1 466 echo -n "testing --until=mm:ss (encode) $desc... "
Chris@1 467 run_flac $eopt --until=0:04 -o z50c.until0:04.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 468 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.until0:04.$in_fmt z50c.until0:04.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 469 $CMP 50c.until40.$in_fmt z50c.until0:04.$in_fmt || die "ERROR: file mismatch for --until=0:04 (encode) $desc"
Chris@1 470 rm -f z50c.until0:04.$out_fmt z50c.until0:04.$in_fmt
Chris@1 471 echo OK
Chris@1 472
Chris@1 473 echo -n "testing --until=mm:ss.sss (encode) $desc... "
Chris@1 474 run_flac $eopt --until=0:03.9001 -o z50c.until0:03.9001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 475 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.until0:03.9001.$in_fmt z50c.until0:03.9001.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 476 $CMP 50c.until39.$in_fmt z50c.until0:03.9001.$in_fmt || die "ERROR: file mismatch for --until=0:03.9001 (encode) $desc"
Chris@1 477 rm -f z50c.until0:03.9001.$out_fmt z50c.until0:03.9001.$in_fmt
Chris@1 478 echo OK
Chris@1 479
Chris@1 480 echo -n "testing --until=-# (encode) $desc... "
Chris@1 481 run_flac $eopt --until=-10 -o z50c.until-10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 482 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.until-10.$in_fmt z50c.until-10.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 483 $CMP 50c.until40.$in_fmt z50c.until-10.$in_fmt || die "ERROR: file mismatch for --until=-10 (encode) $desc"
Chris@1 484 rm -f z50c.until-10.$out_fmt z50c.until-10.$in_fmt
Chris@1 485 echo OK
Chris@1 486
Chris@1 487 echo -n "testing --until=-mm:ss (encode) $desc... "
Chris@1 488 run_flac $eopt --until=-0:01 -o z50c.until-0:01.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 489 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.until-0:01.$in_fmt z50c.until-0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 490 $CMP 50c.until40.$in_fmt z50c.until-0:01.$in_fmt || die "ERROR: file mismatch for --until=-0:01 (encode) $desc"
Chris@1 491 rm -f z50c.until-0:01.$out_fmt z50c.until-0:01.$in_fmt
Chris@1 492 echo OK
Chris@1 493
Chris@1 494 echo -n "testing --until=-mm:ss.sss (encode) $desc... "
Chris@1 495 run_flac $eopt --until=-0:01.1001 -o z50c.until-0:01.1001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 496 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.until-0:01.1001.$in_fmt z50c.until-0:01.1001.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 497 $CMP 50c.until39.$in_fmt z50c.until-0:01.1001.$in_fmt || die "ERROR: file mismatch for --until=-0:01.1001 (encode) $desc"
Chris@1 498 rm -f z50c.until-0:01.1001.$out_fmt z50c.until-0:01.1001.$in_fmt
Chris@1 499 echo OK
Chris@1 500
Chris@1 501 #
Chris@1 502 # test --until when decoding
Chris@1 503 #
Chris@1 504
Chris@1 505 if [ $in_fmt != $out_fmt ] ; then run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt ; else cp -f 50c.$in_fmt z50c.$out_fmt ; fi || die "ERROR generating FLAC file $desc"
Chris@1 506
Chris@1 507 echo -n "testing --until=# (decode) $desc... "
Chris@1 508 run_flac $dopt --until=40 -o z50c.until40.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 509 $CMP 50c.until40.$in_fmt z50c.until40.$in_fmt || die "ERROR: file mismatch for --until=40 (decode) $desc"
Chris@1 510 rm -f z50c.until40.$in_fmt
Chris@1 511 echo OK
Chris@1 512
Chris@1 513 echo -n "testing --until=mm:ss (decode) $desc... "
Chris@1 514 run_flac $dopt --until=0:04 -o z50c.until0:04.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 515 $CMP 50c.until40.$in_fmt z50c.until0:04.$in_fmt || die "ERROR: file mismatch for --until=0:04 (decode) $desc"
Chris@1 516 rm -f z50c.until0:04.$in_fmt
Chris@1 517 echo OK
Chris@1 518
Chris@1 519 echo -n "testing --until=mm:ss.sss (decode) $desc... "
Chris@1 520 run_flac $dopt --until=0:03.9001 -o z50c.until0:03.9001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 521 $CMP 50c.until39.$in_fmt z50c.until0:03.9001.$in_fmt || die "ERROR: file mismatch for --until=0:03.9001 (decode) $desc"
Chris@1 522 rm -f z50c.until0:03.9001.$in_fmt
Chris@1 523 echo OK
Chris@1 524
Chris@1 525 echo -n "testing --until=-# (decode) $desc... "
Chris@1 526 run_flac $dopt --until=-10 -o z50c.until-10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 527 $CMP 50c.until40.$in_fmt z50c.until-10.$in_fmt || die "ERROR: file mismatch for --until=-10 (decode) $desc"
Chris@1 528 rm -f z50c.until-10.$in_fmt
Chris@1 529 echo OK
Chris@1 530
Chris@1 531 echo -n "testing --until=-mm:ss (decode) $desc... "
Chris@1 532 run_flac $dopt --until=-0:01 -o z50c.until-0:01.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 533 $CMP 50c.until40.$in_fmt z50c.until-0:01.$in_fmt || die "ERROR: file mismatch for --until=-0:01 (decode) $desc"
Chris@1 534 rm -f z50c.until-0:01.$in_fmt
Chris@1 535 echo OK
Chris@1 536
Chris@1 537 echo -n "testing --until=-mm:ss.sss (decode) $desc... "
Chris@1 538 run_flac $dopt --until=-0:01.1001 -o z50c.until-0:01.1001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 539 $CMP 50c.until39.$in_fmt z50c.until-0:01.1001.$in_fmt || die "ERROR: file mismatch for --until=-0:01.1001 (decode) $desc"
Chris@1 540 rm -f z50c.until-0:01.1001.$in_fmt
Chris@1 541 echo OK
Chris@1 542
Chris@1 543 rm -f z50c.$out_fmt
Chris@1 544
Chris@1 545 #
Chris@1 546 # test --skip and --until when encoding
Chris@1 547 #
Chris@1 548
Chris@1 549 echo -n "testing --skip=10 --until=# (encode) $desc... "
Chris@1 550 run_flac $eopt --skip=10 --until=40 -o z50c.skip10.until40.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 551 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip10.until40.$in_fmt z50c.skip10.until40.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 552 $CMP 50c.skip10.until40.$in_fmt z50c.skip10.until40.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=40 (encode) $desc"
Chris@1 553 rm -f z50c.skip10.until40.$out_fmt z50c.skip10.until40.$in_fmt
Chris@1 554 echo OK
Chris@1 555
Chris@1 556 echo -n "testing --skip=10 --until=mm:ss (encode) $desc... "
Chris@1 557 run_flac $eopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 558 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip10.until0:04.$in_fmt z50c.skip10.until0:04.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 559 $CMP 50c.skip10.until40.$in_fmt z50c.skip10.until0:04.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=0:04 (encode) $desc"
Chris@1 560 rm -f z50c.skip10.until0:04.$out_fmt z50c.skip10.until0:04.$in_fmt
Chris@1 561 echo OK
Chris@1 562
Chris@1 563 echo -n "testing --skip=10 --until=mm:ss.sss (encode) $desc... "
Chris@1 564 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"
Chris@1 565 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip10.until0:03.9001.$in_fmt z50c.skip10.until0:03.9001.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 566 $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"
Chris@1 567 rm -f z50c.skip10.until0:03.9001.$out_fmt z50c.skip10.until0:03.9001.$in_fmt
Chris@1 568 echo OK
Chris@1 569
Chris@1 570 echo -n "testing --skip=10 --until=+# (encode) $desc... "
Chris@1 571 run_flac $eopt --skip=10 --until=+30 -o z50c.skip10.until+30.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 572 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip10.until+30.$in_fmt z50c.skip10.until+30.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 573 $CMP 50c.skip10.until40.$in_fmt z50c.skip10.until+30.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=+30 (encode) $desc"
Chris@1 574 rm -f z50c.skip10.until+30.$out_fmt z50c.skip10.until+30.$in_fmt
Chris@1 575 echo OK
Chris@1 576
Chris@1 577 echo -n "testing --skip=10 --until=+mm:ss (encode) $desc... "
Chris@1 578 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"
Chris@1 579 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip10.until+0:03.$in_fmt z50c.skip10.until+0:03.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 580 $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"
Chris@1 581 rm -f z50c.skip10.until+0:03.$out_fmt z50c.skip10.until+0:03.$in_fmt
Chris@1 582 echo OK
Chris@1 583
Chris@1 584 echo -n "testing --skip=10 --until=+mm:ss.sss (encode) $desc... "
Chris@1 585 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"
Chris@1 586 [ $in_fmt = $out_fmt ] || 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"
Chris@1 587 $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"
Chris@1 588 rm -f z50c.skip10.until+0:02.9001.$out_fmt z50c.skip10.until+0:02.9001.$in_fmt
Chris@1 589 echo OK
Chris@1 590
Chris@1 591 echo -n "testing --skip=10 --until=-# (encode) $desc... "
Chris@1 592 run_flac $eopt --skip=10 --until=-10 -o z50c.skip10.until-10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 593 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip10.until-10.$in_fmt z50c.skip10.until-10.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 594 $CMP 50c.skip10.until40.$in_fmt z50c.skip10.until-10.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-10 (encode) $desc"
Chris@1 595 rm -f z50c.skip10.until-10.$out_fmt z50c.skip10.until-10.$in_fmt
Chris@1 596 echo OK
Chris@1 597
Chris@1 598 echo -n "testing --skip=10 --until=-mm:ss (encode) $desc... "
Chris@1 599 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"
Chris@1 600 [ $in_fmt = $out_fmt ] || run_flac $dopt -o z50c.skip10.until-0:01.$in_fmt z50c.skip10.until-0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 601 $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"
Chris@1 602 rm -f z50c.skip10.until-0:01.$out_fmt z50c.skip10.until-0:01.$in_fmt
Chris@1 603 echo OK
Chris@1 604
Chris@1 605 echo -n "testing --skip=10 --until=-mm:ss.sss (encode) $desc... "
Chris@1 606 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"
Chris@1 607 [ $in_fmt = $out_fmt ] || 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"
Chris@1 608 $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"
Chris@1 609 rm -f z50c.skip10.until-0:01.1001.$out_fmt z50c.skip10.until-0:01.1001.$in_fmt
Chris@1 610 echo OK
Chris@1 611
Chris@1 612 #
Chris@1 613 # test --skip and --until when decoding
Chris@1 614 #
Chris@1 615
Chris@1 616 if [ $in_fmt != $out_fmt ] ; then run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt ; else cp -f 50c.$in_fmt z50c.$out_fmt ; fi || die "ERROR generating FLAC file $desc"
Chris@1 617
Chris@1 618
Chris@1 619 echo -n "testing --skip=10 --until=# (decode) $desc... "
Chris@1 620 run_flac $dopt --skip=10 --until=40 -o z50c.skip10.until40.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 621 $CMP 50c.skip10.until40.$in_fmt z50c.skip10.until40.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=40 (decode) $desc"
Chris@1 622 rm -f z50c.skip10.until40.$in_fmt
Chris@1 623 echo OK
Chris@1 624
Chris@1 625 echo -n "testing --skip=10 --until=mm:ss (decode) $desc... "
Chris@1 626 run_flac $dopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 627 $CMP 50c.skip10.until40.$in_fmt z50c.skip10.until0:04.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=0:04 (decode) $desc"
Chris@1 628 rm -f z50c.skip10.until0:04.$in_fmt
Chris@1 629 echo OK
Chris@1 630
Chris@1 631 echo -n "testing --skip=10 --until=mm:ss.sss (decode) $desc... "
Chris@1 632 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"
Chris@1 633 $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"
Chris@1 634 rm -f z50c.skip10.until0:03.9001.$in_fmt
Chris@1 635 echo OK
Chris@1 636
Chris@1 637 echo -n "testing --skip=10 --until=-# (decode) $desc... "
Chris@1 638 run_flac $dopt --skip=10 --until=-10 -o z50c.skip10.until-10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 639 $CMP 50c.skip10.until40.$in_fmt z50c.skip10.until-10.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-10 (decode) $desc"
Chris@1 640 rm -f z50c.skip10.until-10.$in_fmt
Chris@1 641 echo OK
Chris@1 642
Chris@1 643 echo -n "testing --skip=10 --until=-mm:ss (decode) $desc... "
Chris@1 644 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"
Chris@1 645 $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"
Chris@1 646 rm -f z50c.skip10.until-0:01.$in_fmt
Chris@1 647 echo OK
Chris@1 648
Chris@1 649 echo -n "testing --skip=10 --until=-mm:ss.sss (decode) $desc... "
Chris@1 650 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"
Chris@1 651 $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"
Chris@1 652 rm -f z50c.skip10.until-0:01.1001.$in_fmt
Chris@1 653 echo OK
Chris@1 654
Chris@1 655 rm -f z50c.$out_fmt
Chris@1 656 }
Chris@1 657
Chris@1 658 test_skip_until raw flac
Chris@1 659 test_skip_until wav flac
Chris@1 660 test_skip_until aiff flac
Chris@1 661 test_skip_until flac flac
Chris@1 662 #@@@if [ $has_ogg = yes ] ; then
Chris@1 663 #@@@ #@@@ doesn't work yet because md5cmp doesn't work because metaflac doesn't work on ogg flac yet
Chris@1 664 #@@@ test_skip_until ogg flac
Chris@1 665 #@@@fi
Chris@1 666
Chris@1 667 if [ $has_ogg = yes ] ; then
Chris@1 668 test_skip_until raw ogg
Chris@1 669 test_skip_until wav ogg
Chris@1 670 test_skip_until aiff ogg
Chris@1 671 #@@@ doesn't work yet because md5cmp doesn't work because metaflac doesn't work on ogg flac yet
Chris@1 672 #@@@test_skip_until flac ogg
Chris@1 673 #@@@test_skip_until ogg ogg
Chris@1 674 fi
Chris@1 675
Chris@1 676 echo "testing seek extremes:"
Chris@1 677
Chris@1 678 run_flac --verify --force $SILENT --no-padding --force-raw-format --endian=big --sign=signed --sample-rate=44100 --bps=16 --channels=2 --blocksize=576 noise.raw || die "ERROR generating FLAC file"
Chris@1 679
Chris@1 680 if [ $is_win = no ] ; then
Chris@1 681 total_noise_cdda_samples=`run_metaflac --show-total-samples noise.flac`
Chris@1 682 [ $? = 0 ] || die "ERROR getting total sample count from noise.flac"
Chris@1 683 else
Chris@1 684 # some flavors of cygwin don't seem to treat the \x0d as a word
Chris@1 685 # separator, so we hard code it. we'll just have to fix it later
Chris@1 686 # if we change the way noise.flac is made.
Chris@1 687 total_noise_cdda_samples=393216
Chris@1 688 fi
Chris@1 689
Chris@1 690 echo -n "testing --skip=0... "
Chris@1 691 run_flac $wav_dopt --skip=0 -o z.wav noise.flac || die "ERROR decoding FLAC file noise.flac"
Chris@1 692 echo OK
Chris@1 693
Chris@1 694 for delta in 2 1 ; do
Chris@1 695 n=`expr $total_noise_cdda_samples - $delta`
Chris@1 696 echo -n "testing --skip=$n... "
Chris@1 697 run_flac $wav_dopt --skip=$n -o z.wav noise.flac || die "ERROR decoding FLAC file noise.flac"
Chris@1 698 echo OK
Chris@1 699 done
Chris@1 700
Chris@1 701 rm noise.flac z.wav
Chris@1 702
Chris@1 703
Chris@1 704 ############################################################################
Chris@1 705 # test --input-size
Chris@1 706 ############################################################################
Chris@1 707
Chris@1 708 #@@@ cat will not work on old cygwin, need to fix
Chris@1 709 if [ $is_win = no ] ; then
Chris@1 710 echo -n "testing --input-size=50 --skip=10... "
Chris@1 711 cat 50c.raw | run_flac $raw_eopt --input-size=50 --skip=10 -o z50c.skip10.flac - || die "ERROR generating FLAC file"
Chris@1 712 run_flac $raw_dopt -o z50c.skip10.raw z50c.skip10.flac || die "ERROR decoding FLAC file"
Chris@1 713 cmp 50c.skip10.raw z50c.skip10.raw || die "ERROR: file mismatch for --input-size=50 --skip=10"
Chris@1 714 rm -f z50c.skip10.raw z50c.skip10.flac
Chris@1 715 echo OK
Chris@1 716 fi
Chris@1 717
Chris@1 718
Chris@1 719 ############################################################################
Chris@1 720 # test --cue
Chris@1 721 ############################################################################
Chris@1 722
Chris@1 723 #
Chris@1 724 # create the cue sheet
Chris@1 725 #
Chris@1 726 cuesheet=cuetest.cue
Chris@1 727 cat > $cuesheet << EOF
Chris@1 728 CATALOG 1234567890123
Chris@1 729 FILE "blah" WAVE
Chris@1 730 TRACK 01 AUDIO
Chris@1 731 INDEX 01 0
Chris@1 732 INDEX 02 10
Chris@1 733 INDEX 03 20
Chris@1 734 TRACK 02 AUDIO
Chris@1 735 INDEX 01 30
Chris@1 736 TRACK 04 AUDIO
Chris@1 737 INDEX 01 40
Chris@1 738 EOF
Chris@1 739
Chris@1 740 test_cue ()
Chris@1 741 {
Chris@1 742 in_fmt=$1
Chris@1 743 out_fmt=$2
Chris@1 744
Chris@1 745 [ "$in_fmt" = wav ] || [ "$in_fmt" = aiff ] || [ "$in_fmt" = raw ] || [ "$in_fmt" = flac ] || [ "$in_fmt" = ogg ] || die "ERROR: internal error, bad 'in' format '$in_fmt'"
Chris@1 746
Chris@1 747 [ "$out_fmt" = flac ] || [ "$out_fmt" = ogg ] || die "ERROR: internal error, bad 'out' format '$out_fmt'"
Chris@1 748
Chris@1 749 if [ $in_fmt = raw ] ; then
Chris@1 750 eopt="$raw_eopt"
Chris@1 751 dopt="$raw_dopt"
Chris@1 752 else
Chris@1 753 eopt="$wav_eopt"
Chris@1 754 dopt="$wav_dopt"
Chris@1 755 fi
Chris@1 756
Chris@1 757 if ( [ $in_fmt = flac ] || [ $in_fmt = ogg ] ) && ( [ $out_fmt = flac ] || [ $out_fmt = ogg ] ) ; then
Chris@1 758 CMP=md5cmp
Chris@1 759 else
Chris@1 760 CMP=cmp
Chris@1 761 fi
Chris@1 762
Chris@1 763 if [ $out_fmt = ogg ] ; then
Chris@1 764 eopt="--ogg $eopt"
Chris@1 765 fi
Chris@1 766
Chris@1 767 desc="($in_fmt<->$out_fmt)"
Chris@1 768
Chris@1 769 #
Chris@1 770 # for this we need just need just one FLAC file; --cue only works while decoding
Chris@1 771 #
Chris@1 772 run_flac $eopt --cuesheet=$cuesheet -o z50c.cue.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
Chris@1 773
Chris@1 774 # To make it easy to translate from cue point to sample numbers, the
Chris@1 775 # file has a sample rate of 10 Hz and a cuesheet like so:
Chris@1 776 #
Chris@1 777 # TRACK 01, INDEX 01 : 0:00.00 -> sample 0
Chris@1 778 # TRACK 01, INDEX 02 : 0:01.00 -> sample 10
Chris@1 779 # TRACK 01, INDEX 03 : 0:02.00 -> sample 20
Chris@1 780 # TRACK 02, INDEX 01 : 0:03.00 -> sample 30
Chris@1 781 # TRACK 04, INDEX 01 : 0:04.00 -> sample 40
Chris@1 782 #
Chris@1 783 echo -n "testing --cue=- $desc... "
Chris@1 784 run_flac $dopt -o z50c.cued.$in_fmt --cue=- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 785 $CMP 50c.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=- $desc"
Chris@1 786 rm -f z50c.cued.$in_fmt
Chris@1 787 echo OK
Chris@1 788
Chris@1 789 echo -n "testing --cue=1.0 $desc... "
Chris@1 790 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 791 $CMP 50c.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.0 $desc"
Chris@1 792 rm -f z50c.cued.$in_fmt
Chris@1 793 echo OK
Chris@1 794
Chris@1 795 echo -n "testing --cue=1.0- $desc... "
Chris@1 796 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.0- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 797 $CMP 50c.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.0- $desc"
Chris@1 798 rm -f z50c.cued.$in_fmt
Chris@1 799 echo OK
Chris@1 800
Chris@1 801 echo -n "testing --cue=1.1 $desc... "
Chris@1 802 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 803 $CMP 50c.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.1 $desc"
Chris@1 804 rm -f z50c.cued.$in_fmt
Chris@1 805 echo OK
Chris@1 806
Chris@1 807 echo -n "testing --cue=1.1- $desc... "
Chris@1 808 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.1- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 809 $CMP 50c.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.1- $desc"
Chris@1 810 rm -f z50c.cued.$in_fmt
Chris@1 811 echo OK
Chris@1 812
Chris@1 813 echo -n "testing --cue=1.2 $desc... "
Chris@1 814 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.2 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 815 $CMP 50c.skip10.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.2 $desc"
Chris@1 816 rm -f z50c.cued.$in_fmt
Chris@1 817 echo OK
Chris@1 818
Chris@1 819 echo -n "testing --cue=1.2- $desc... "
Chris@1 820 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.2- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 821 $CMP 50c.skip10.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.2- $desc"
Chris@1 822 rm -f z50c.cued.$in_fmt
Chris@1 823 echo OK
Chris@1 824
Chris@1 825 echo -n "testing --cue=1.4 $desc... "
Chris@1 826 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.4 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 827 $CMP 50c.skip20.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.4 $desc"
Chris@1 828 rm -f z50c.cued.$in_fmt
Chris@1 829 echo OK
Chris@1 830
Chris@1 831 echo -n "testing --cue=1.4- $desc... "
Chris@1 832 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.4- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 833 $CMP 50c.skip20.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.4- $desc"
Chris@1 834 rm -f z50c.cued.$in_fmt
Chris@1 835 echo OK
Chris@1 836
Chris@1 837 echo -n "testing --cue=-5.0 $desc... "
Chris@1 838 run_flac $dopt -o z50c.cued.$in_fmt --cue=-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 839 $CMP 50c.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=-5.0 $desc"
Chris@1 840 rm -f z50c.cued.$in_fmt
Chris@1 841 echo OK
Chris@1 842
Chris@1 843 echo -n "testing --cue=-4.1 $desc... "
Chris@1 844 run_flac $dopt -o z50c.cued.$in_fmt --cue=-4.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 845 $CMP 50c.until40.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=-4.1 $desc"
Chris@1 846 rm -f z50c.cued.$in_fmt
Chris@1 847 echo OK
Chris@1 848
Chris@1 849 echo -n "testing --cue=-3.1 $desc... "
Chris@1 850 run_flac $dopt -o z50c.cued.$in_fmt --cue=-3.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 851 $CMP 50c.until40.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=-3.1 $desc"
Chris@1 852 rm -f z50c.cued.$in_fmt
Chris@1 853 echo OK
Chris@1 854
Chris@1 855 echo -n "testing --cue=-1.4 $desc... "
Chris@1 856 run_flac $dopt -o z50c.cued.$in_fmt --cue=-1.4 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 857 $CMP 50c.until30.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=-1.4 $desc"
Chris@1 858 rm -f z50c.cued.$in_fmt
Chris@1 859 echo OK
Chris@1 860
Chris@1 861 echo -n "testing --cue=1.0-5.0 $desc... "
Chris@1 862 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.0-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 863 $CMP 50c.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.0-5.0 $desc"
Chris@1 864 rm -f z50c.cued.$in_fmt
Chris@1 865 echo OK
Chris@1 866
Chris@1 867 echo -n "testing --cue=1.1-5.0 $desc... "
Chris@1 868 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.1-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 869 $CMP 50c.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.1-5.0 $desc"
Chris@1 870 rm -f z50c.cued.$in_fmt
Chris@1 871 echo OK
Chris@1 872
Chris@1 873 echo -n "testing --cue=1.2-4.1 $desc... "
Chris@1 874 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.2-4.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 875 $CMP 50c.skip10.until40.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.2-4.1 $desc"
Chris@1 876 rm -f z50c.cued.$in_fmt
Chris@1 877 echo OK
Chris@1 878
Chris@1 879 echo -n "testing --cue=1.4-2.0 $desc... "
Chris@1 880 run_flac $dopt -o z50c.cued.$in_fmt --cue=1.4-2.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
Chris@1 881 $CMP 50c.skip20.until30.$in_fmt z50c.cued.$in_fmt || die "ERROR: file mismatch for --cue=1.4-2.0 $desc"
Chris@1 882 rm -f z50c.cued.$in_fmt
Chris@1 883 echo OK
Chris@1 884
Chris@1 885 rm -f z50c.cue.$out_fmt
Chris@1 886 }
Chris@1 887
Chris@1 888 test_cue raw flac
Chris@1 889 test_cue wav flac
Chris@1 890 test_cue aiff flac
Chris@1 891 test_cue flac flac
Chris@1 892 #@@@if [ $has_ogg = yes ] ; then
Chris@1 893 #@@@ #@@@ doesn't work yet because md5cmp doesn't work because metaflac doesn't work on ogg flac yet
Chris@1 894 #@@@ test_cue ogg flac
Chris@1 895 #@@@fi
Chris@1 896
Chris@1 897 if [ $has_ogg = yes ] ; then
Chris@1 898 test_cue raw ogg
Chris@1 899 test_cue wav ogg
Chris@1 900 test_cue aiff ogg
Chris@1 901 #@@@ doesn't work yet because md5cmp doesn't work because metaflac doesn't work on ogg flac yet
Chris@1 902 #@@@test_cue flac ogg
Chris@1 903 #@@@test_cue ogg ogg
Chris@1 904 fi
Chris@1 905
Chris@1 906 ############################################################################
Chris@1 907 # test 'fixup' code that happens when a FLAC file with total_samples == 0
Chris@1 908 # in the STREAMINFO block is converted to WAVE or AIFF, requiring the
Chris@1 909 # decoder go back and fix up the chunk headers
Chris@1 910 ############################################################################
Chris@1 911
Chris@1 912 echo -n "WAVE fixup test... "
Chris@1 913
Chris@1 914 echo -n "prepare... "
Chris@1 915 convert_to_wav noise "$raw_eopt" "$wav_dopt" || die "ERROR creating reference WAVE"
Chris@1 916
Chris@1 917 echo -n "encode... "
Chris@1 918 # the pipe from 'cat' to 'flac' does not work on cygwin because of the EOF/
Chris@1 919 # binary-mode stdin problem, so we use an undocumented option to metaflac to
Chris@1 920 # set the total sample count to 0
Chris@1 921 if [ $is_win = yes ] ; then
Chris@1 922 run_flac $raw_eopt noise.raw -o fixup.flac || die "ERROR generating FLAC file"
Chris@1 923 run_metaflac --set-total-samples=0 fixup.flac 2> /dev/null
Chris@1 924 else
Chris@1 925 cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
Chris@1 926 fi
Chris@1 927
Chris@1 928 echo -n "decode... "
Chris@1 929 run_flac $wav_dopt fixup.flac -o fixup.wav || die "ERROR decoding FLAC file"
Chris@1 930
Chris@1 931 echo -n "compare... "
Chris@1 932 cmp noise.wav fixup.wav || die "ERROR: file mismatch"
Chris@1 933
Chris@1 934 echo OK
Chris@1 935 rm -f noise.wav fixup.wav fixup.flac
Chris@1 936
Chris@1 937 echo -n "AIFF fixup test... "
Chris@1 938
Chris@1 939 echo -n "prepare... "
Chris@1 940 convert_to_aiff noise "$raw_eopt" "$wav_dopt" || die "ERROR creating reference AIFF"
Chris@1 941
Chris@1 942 echo -n "encode... "
Chris@1 943 # the pipe from 'cat' to 'flac' does not work on cygwin because of the EOF/
Chris@1 944 # binary-mode stdin problem, so we use an undocumented option to metaflac to
Chris@1 945 # set the total sample count to 0
Chris@1 946 if [ $is_win = yes ] ; then
Chris@1 947 run_flac $raw_eopt noise.raw -o fixup.flac || die "ERROR generating FLAC file"
Chris@1 948 run_metaflac --set-total-samples=0 fixup.flac 2> /dev/null
Chris@1 949 else
Chris@1 950 cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
Chris@1 951 fi
Chris@1 952
Chris@1 953 echo -n "decode... "
Chris@1 954 run_flac $wav_dopt fixup.flac -o fixup.aiff || die "ERROR decoding FLAC file"
Chris@1 955
Chris@1 956 echo -n "compare... "
Chris@1 957 cmp noise.aiff fixup.aiff || die "ERROR: file mismatch"
Chris@1 958
Chris@1 959 echo OK
Chris@1 960 rm -f noise.aiff fixup.aiff fixup.flac
Chris@1 961
Chris@1 962
Chris@1 963 ############################################################################
Chris@1 964 # multi-file tests
Chris@1 965 ############################################################################
Chris@1 966
Chris@1 967 echo "Generating multiple input files from noise..."
Chris@1 968 multifile_format_decode="--endian=big --sign=signed"
Chris@1 969 multifile_format_encode="$multifile_format_decode --sample-rate=44100 --bps=16 --channels=2 --no-padding"
Chris@1 970 short_noise_cdda_samples=`expr $total_noise_cdda_samples / 8`
Chris@1 971 run_flac --verify --force $SILENT --force-raw-format $multifile_format_encode --until=$short_noise_cdda_samples -o shortnoise.flac noise.raw || die "ERROR generating FLAC file"
Chris@1 972 run_flac --decode --force $SILENT shortnoise.flac -o shortnoise.raw --force-raw-format $multifile_format_decode || die "ERROR generating RAW file"
Chris@1 973 run_flac --decode --force $SILENT shortnoise.flac || die "ERROR generating WAVE file"
Chris@1 974 run_flac --decode --force $SILENT shortnoise.flac -o shortnoise.aiff || die "ERROR generating AIFF file"
Chris@1 975 cp shortnoise.flac file0.flac
Chris@1 976 cp shortnoise.flac file1.flac
Chris@1 977 cp shortnoise.flac file2.flac
Chris@1 978 rm -f shortnoise.flac
Chris@1 979 cp shortnoise.wav file0.wav
Chris@1 980 cp shortnoise.wav file1.wav
Chris@1 981 cp shortnoise.wav file2.wav
Chris@1 982 rm -f shortnoise.wav
Chris@1 983 cp shortnoise.aiff file0.aiff
Chris@1 984 cp shortnoise.aiff file1.aiff
Chris@1 985 cp shortnoise.aiff file2.aiff
Chris@1 986 rm -f shortnoise.aiff
Chris@1 987 cp shortnoise.raw file0.raw
Chris@1 988 cp shortnoise.raw file1.raw
Chris@1 989 cp shortnoise.raw file2.raw
Chris@1 990 rm -f shortnoise.raw
Chris@1 991 # create authoritative sector-aligned files for comparison
Chris@1 992 file0_samples=`expr \( $short_noise_cdda_samples / 588 \) \* 588`
Chris@1 993 file0_remainder=`expr $short_noise_cdda_samples - $file0_samples`
Chris@1 994 file1_samples=`expr \( \( $file0_remainder + $short_noise_cdda_samples \) / 588 \) \* 588`
Chris@1 995 file1_remainder=`expr $file0_remainder + $short_noise_cdda_samples - $file1_samples`
Chris@1 996 file1_samples=`expr $file1_samples - $file0_remainder`
Chris@1 997 file2_samples=`expr \( \( $file1_remainder + $short_noise_cdda_samples \) / 588 \) \* 588`
Chris@1 998 file2_remainder=`expr $file1_remainder + $short_noise_cdda_samples - $file2_samples`
Chris@1 999 file2_samples=`expr $file2_samples - $file1_remainder`
Chris@1 1000 if [ $file2_remainder != '0' ] ; then
Chris@1 1001 file2_samples=`expr $file2_samples + $file2_remainder`
Chris@1 1002 file2_remainder=`expr 588 - $file2_remainder`
Chris@1 1003 fi
Chris@1 1004
Chris@1 1005 dd if=file0.raw ibs=4 count=$file0_samples of=file0s.raw 2>/dev/null || $dddie
Chris@1 1006 dd if=file0.raw ibs=4 count=$file0_remainder of=file1s.raw skip=$file0_samples 2>/dev/null || $dddie
Chris@1 1007 dd if=file1.raw ibs=4 count=$file1_samples of=z.raw 2>/dev/null || $dddie
Chris@1 1008 cat z.raw >> file1s.raw || die "ERROR: cat-ing sector-aligned files"
Chris@1 1009 dd if=file1.raw ibs=4 count=$file1_remainder of=file2s.raw skip=$file1_samples 2>/dev/null || $dddie
Chris@1 1010 dd if=file2.raw ibs=4 count=$file2_samples of=z.raw 2>/dev/null || $dddie
Chris@1 1011 cat z.raw >> file2s.raw || die "ERROR: cat-ing sector-aligned files"
Chris@1 1012 dd if=/dev/zero ibs=4 count=$file2_remainder of=z.raw 2>/dev/null || $dddie
Chris@1 1013 cat z.raw >> file2s.raw || die "ERROR: cat-ing sector-aligned files"
Chris@1 1014 rm -f z.raw
Chris@1 1015
Chris@1 1016 convert_to_wav file0s "$multifile_format_encode --force" "$SILENT --force --decode" || die "ERROR creating authoritative sector-aligned WAVE"
Chris@1 1017 convert_to_wav file1s "$multifile_format_encode --force" "$SILENT --force --decode" || die "ERROR creating authoritative sector-aligned WAVE"
Chris@1 1018 convert_to_wav file2s "$multifile_format_encode --force" "$SILENT --force --decode" || die "ERROR creating authoritative sector-aligned WAVE"
Chris@1 1019
Chris@1 1020 convert_to_aiff file0s "$multifile_format_encode --force" "$SILENT --force --decode" || die "ERROR creating authoritative sector-aligned AIFF"
Chris@1 1021 convert_to_aiff file1s "$multifile_format_encode --force" "$SILENT --force --decode" || die "ERROR creating authoritative sector-aligned AIFF"
Chris@1 1022 convert_to_aiff file2s "$multifile_format_encode --force" "$SILENT --force --decode" || die "ERROR creating authoritative sector-aligned AIFF"
Chris@1 1023
Chris@1 1024 test_multifile ()
Chris@1 1025 {
Chris@1 1026 input_type=$1
Chris@1 1027 streamtype=$2
Chris@1 1028 sector_align=$3
Chris@1 1029 encode_options="$4"
Chris@1 1030
Chris@1 1031 extra_encode_options=""
Chris@1 1032 extra_decode_options=""
Chris@1 1033 if [ $input_type = "raw" ] ; then
Chris@1 1034 extra_encode_options="--force-raw-format $multifile_format_encode"
Chris@1 1035 extra_decode_options="--force-raw-format $multifile_format_decode"
Chris@1 1036 else
Chris@1 1037 if [ $input_type = "aiff" ] ; then
Chris@1 1038 extra_decode_options="--force-aiff-format"
Chris@1 1039 fi
Chris@1 1040 fi
Chris@1 1041
Chris@1 1042 if [ $streamtype = ogg ] ; then
Chris@1 1043 suffix=oga
Chris@1 1044 encode_options="$encode_options --ogg"
Chris@1 1045 else
Chris@1 1046 suffix=flac
Chris@1 1047 fi
Chris@1 1048
Chris@1 1049 if [ $sector_align = sector_align ] ; then
Chris@1 1050 encode_options="$encode_options --sector-align"
Chris@1 1051 fi
Chris@1 1052
Chris@1 1053 if [ $input_type = flac ] || [ $input_type = ogg ] ; then
Chris@1 1054 CMP=md5cmp
Chris@1 1055 else
Chris@1 1056 CMP=cmp
Chris@1 1057 fi
Chris@1 1058
Chris@1 1059 for n in 0 1 2 ; do
Chris@1 1060 cp file$n.$input_type file${n}x.$input_type
Chris@1 1061 done
Chris@1 1062 run_flac --force $encode_options $extra_encode_options file0x.$input_type file1x.$input_type file2x.$input_type || die "ERROR"
Chris@1 1063 run_flac --force --decode $extra_decode_options file0x.$suffix file1x.$suffix file2x.$suffix || die "ERROR"
Chris@1 1064 if [ $sector_align != sector_align ] ; then
Chris@1 1065 for n in 0 1 2 ; do
Chris@1 1066 $CMP file$n.$input_type file${n}x.$input_type || die "ERROR: file mismatch on file #$n"
Chris@1 1067 done
Chris@1 1068 else
Chris@1 1069 for n in 0 1 2 ; do
Chris@1 1070 $CMP file${n}s.$input_type file${n}x.$input_type || die "ERROR: file mismatch on file #$n"
Chris@1 1071 done
Chris@1 1072 fi
Chris@1 1073 for n in 0 1 2 ; do
Chris@1 1074 rm -f file${n}x.$suffix file${n}x.$input_type
Chris@1 1075 done
Chris@1 1076 }
Chris@1 1077
Chris@1 1078 input_types="raw wav aiff flac"
Chris@1 1079 #@@@ doesn't work yet because md5cmp doesn't work because metaflac doesn't work on ogg flac yet
Chris@1 1080 #@@@if [ $has_ogg = yes ] ; then
Chris@1 1081 #@@@ input_types="$input_types ogg"
Chris@1 1082 #@@@fi
Chris@1 1083 for input_type in $input_types ; do
Chris@1 1084 echo "Testing multiple $input_type files without verify..."
Chris@1 1085 test_multifile $input_type flac no_sector_align ""
Chris@1 1086
Chris@1 1087 echo "Testing multiple $input_type files with verify..."
Chris@1 1088 test_multifile $input_type flac no_sector_align "--verify"
Chris@1 1089
Chris@1 1090 if [ $input_type != flac ] && [ $input_type != ogg ] ; then # --sector-align not supported for FLAC input
Chris@1 1091 echo "Testing multiple $input_type files with --sector-align, without verify..."
Chris@1 1092 test_multifile $input_type flac sector_align ""
Chris@1 1093
Chris@1 1094 echo "Testing multiple $input_type files with --sector-align, with verify..."
Chris@1 1095 test_multifile $input_type flac sector_align "--verify"
Chris@1 1096 fi
Chris@1 1097
Chris@1 1098 if [ $has_ogg = yes ] ; then
Chris@1 1099 echo "Testing multiple $input_type files with --ogg, without verify..."
Chris@1 1100 test_multifile $input_type ogg no_sector_align ""
Chris@1 1101
Chris@1 1102 echo "Testing multiple $input_type files with --ogg, with verify..."
Chris@1 1103 test_multifile $input_type ogg no_sector_align "--verify"
Chris@1 1104
Chris@1 1105 if [ $input_type != flac ] ; then # --sector-align not supported for FLAC input
Chris@1 1106 echo "Testing multiple $input_type files with --ogg and --sector-align, without verify..."
Chris@1 1107 test_multifile $input_type ogg sector_align ""
Chris@1 1108
Chris@1 1109 echo "Testing multiple $input_type files with --ogg and --sector-align, with verify..."
Chris@1 1110 test_multifile $input_type ogg sector_align "--verify"
Chris@1 1111 fi
Chris@1 1112
Chris@1 1113 echo "Testing multiple $input_type files with --ogg and --serial-number, with verify..."
Chris@1 1114 test_multifile $input_type ogg no_sector_align "--serial-number=321 --verify"
Chris@1 1115 fi
Chris@1 1116 done
Chris@1 1117
Chris@1 1118
Chris@1 1119 ############################################################################
Chris@1 1120 # test the metadata-handling properties of flac-to-flac encoding
Chris@1 1121 ############################################################################
Chris@1 1122
Chris@1 1123 echo "Testing the metadata-handling properties of flac-to-flac encoding..."
Chris@1 1124
Chris@1 1125 testdir="flac-to-flac-metadata-test-files"
Chris@1 1126 filter ()
Chris@1 1127 {
Chris@1 1128 # minor danger, changing vendor strings might change the length of the
Chris@1 1129 # VORBIS_COMMENT block, but if we add "^ length: " to the patterns,
Chris@1 1130 # we lose info about PADDING size that we need
Chris@1 1131 grep -Ev '^ vendor string: |^ m..imum .....size: ' | sed -e 's/, stream_offset.*//'
Chris@1 1132 }
Chris@1 1133 flac2flac ()
Chris@1 1134 {
Chris@1 1135 file="$1"
Chris@1 1136 case="$2"
Chris@1 1137 args="$3"
Chris@1 1138 expect="$case-expect.meta"
Chris@1 1139 echo -n "$case... "
Chris@1 1140 run_flac $SILENT -f -o out.flac $args $file || die "ERROR encoding FLAC file"
Chris@1 1141 run_metaflac --list out.flac | filter > out.meta || die "ERROR listing metadata of output FLAC file"
Chris@1 1142 diff -q -w $expect out.meta 2>/dev/null || die "ERROR: metadata does not match expected $expect"
Chris@1 1143 echo OK
Chris@1 1144 }
Chris@1 1145
Chris@1 1146 #filter=', stream_offset.*|^ vendor string: |^ length: |^ m..imum .....size: '
Chris@1 1147 cd $testdir || die "ERROR changing to directory $testdir"
Chris@1 1148
Chris@1 1149 # case 00a: no alterations on a file with all metadata types, keep all metadata, in same order
Chris@1 1150 flac2flac input-SCVAUP.flac case00a ""
Chris@1 1151 # case 01a: on file with multiple PADDING blocks, they should be aggregated into one at the end
Chris@1 1152 flac2flac input-SCVPAP.flac case01a ""
Chris@1 1153 # case 01b: on file with multiple PADDING blocks and --no-padding specified, they should all be deleted
Chris@1 1154 flac2flac input-SCVPAP.flac case01b "--no-padding"
Chris@1 1155 # case 01c: on file with multiple PADDING blocks and -P specified, they should all be overwritten with -P value
Chris@1 1156 flac2flac input-SCVPAP.flac case01c "-P 1234"
Chris@1 1157 # case 01d: on file with no PADDING blocks, use -P setting
Chris@1 1158 flac2flac input-SCVA.flac case01d "-P 1234"
Chris@1 1159 # case 01e: on file with no PADDING blocks and no -P given, use default padding
Chris@1 1160 flac2flac input-SCVA.flac case01e ""
Chris@1 1161 # case 02a: on file with no VORBIS_COMMENT block, add new VORBIS_COMMENT
Chris@1 1162 flac2flac input-SCPAP.flac case02a ""
Chris@1 1163 # case 02b: on file with no VORBIS_COMMENT block and --tag, add new VORBIS_COMMENT with tags
Chris@1 1164 flac2flac input-SCPAP.flac case02b "--tag=artist=0"
Chris@1 1165 # case 02c: on file with VORBIS_COMMENT block and --tag, replace existing VORBIS_COMMENT with new tags
Chris@1 1166 flac2flac input-SCVAUP.flac case02c "$TOTALLY_SILENT --tag=artist=0"
Chris@1 1167 # case 03a: on file with no CUESHEET block and --cuesheet specified, add it
Chris@1 1168 flac2flac input-SVAUP.flac case03a "--cuesheet=input0.cue"
Chris@1 1169 # case 03b: on file with CUESHEET block and --cuesheet specified, overwrite existing CUESHEET
Chris@1 1170 flac2flac input-SCVAUP.flac case03b "$TOTALLY_SILENT --cuesheet=input0.cue"
Chris@1 1171 # case 03c: on file with CUESHEET block and size-changing option specified, drop existing CUESHEET
Chris@1 1172 flac2flac input-SCVAUP.flac case03c "$TOTALLY_SILENT --skip=1"
Chris@1 1173 # case 04a: on file with no SEEKTABLE block and --no-seektable specified, no SEEKTABLE
Chris@1 1174 flac2flac input-VA.flac case04a "--no-padding --no-seektable"
Chris@1 1175 # case 04b: on file with no SEEKTABLE block and -S specified, new SEEKTABLE
Chris@1 1176 flac2flac input-VA.flac case04b "--no-padding -S 5x"
Chris@1 1177 # case 04c: on file with no SEEKTABLE block and no seektable options specified, new SEEKTABLE with default points
Chris@1 1178 flac2flac input-VA.flac case04c "--no-padding"
Chris@1 1179 # case 04d: on file with SEEKTABLE block and --no-seektable specified, drop existing SEEKTABLE
Chris@1 1180 flac2flac input-SCVA.flac case04d "--no-padding --no-seektable"
Chris@1 1181 # case 04e: on file with SEEKTABLE block and -S specified, overwrite existing SEEKTABLE
Chris@1 1182 flac2flac input-SCVA.flac case04e "$TOTALLY_SILENT --no-padding -S 5x"
Chris@1 1183 # case 04f: on file with SEEKTABLE block and size-changing option specified, drop existing SEEKTABLE, new SEEKTABLE with default points
Chris@1 1184 #(already covered by case03c)
Chris@1 1185
Chris@1 1186 rm -f out.flac out.meta
Chris@1 1187
Chris@1 1188 #@@@ when metaflac handles ogg flac, duplicate flac2flac tests here
Chris@1 1189
Chris@1 1190 cd ..