about summary refs log tree commit
path: root/test/test_metaflac.sh
diff options
context:
space:
mode:
Diffstat (limited to 'test/test_metaflac.sh')
-rwxr-xr-xtest/test_metaflac.sh346
1 files changed, 161 insertions, 185 deletions
diff --git a/test/test_metaflac.sh b/test/test_metaflac.sh
index 1022ef30..13860f33 100755
--- a/test/test_metaflac.sh
+++ b/test/test_metaflac.sh
@@ -23,26 +23,36 @@ die ()
         exit 1
 }
 
-if [ x = x"$1" ] ; then
+if [ x = x"$1" ] ; then
         BUILD=debug
 else
         BUILD="$1"
 fi
 
-LD_LIBRARY_PATH=../src/libFLAC/.libs:$LD_LIBRARY_PATH
-LD_LIBRARY_PATH=../src/libOggFLAC/.libs:$LD_LIBRARY_PATH
-LD_LIBRARY_PATH=../src/share/grabbag/.libs:$LD_LIBRARY_PATH
-LD_LIBRARY_PATH=../src/share/getopt/.libs:$LD_LIBRARY_PATH
-LD_LIBRARY_PATH=../src/share/replaygain_analysis/.libs:$LD_LIBRARY_PATH
-LD_LIBRARY_PATH=../src/share/replaygain_synthesis/.libs:$LD_LIBRARY_PATH
-LD_LIBRARY_PATH=../src/share/utf8/.libs:$LD_LIBRARY_PATH
-LD_LIBRARY_PATH=../obj/$BUILD/lib:$LD_LIBRARY_PATH
+# change to 'false' to show all flac/metaflac output (useful for debugging)
+if true ; then
+        SILENT='--silent'
+        TOTALLY_SILENT='--totally-silent'
+else
+        SILENT=''
+        TOTALLY_SILENT=''
+fi
+
+LD_LIBRARY_PATH=`pwd`/../src/libFLAC/.libs:$LD_LIBRARY_PATH
+LD_LIBRARY_PATH=`pwd`/../src/libOggFLAC/.libs:$LD_LIBRARY_PATH
+LD_LIBRARY_PATH=`pwd`/../src/share/grabbag/.libs:$LD_LIBRARY_PATH
+LD_LIBRARY_PATH=`pwd`/../src/share/getopt/.libs:$LD_LIBRARY_PATH
+LD_LIBRARY_PATH=`pwd`/../src/share/replaygain_analysis/.libs:$LD_LIBRARY_PATH
+LD_LIBRARY_PATH=`pwd`/../src/share/replaygain_synthesis/.libs:$LD_LIBRARY_PATH
+LD_LIBRARY_PATH=`pwd`/../src/share/utf8/.libs:$LD_LIBRARY_PATH
+LD_LIBRARY_PATH=`pwd`/../obj/$BUILD/lib:$LD_LIBRARY_PATH
 export LD_LIBRARY_PATH
-PATH=../src/flac:$PATH
-PATH=../src/metaflac:$PATH
-PATH=../obj/$BUILD/bin:$PATH
+PATH=`pwd`/../src/flac:$PATH
+PATH=`pwd`/../src/metaflac:$PATH
+PATH=`pwd`/../obj/$BUILD/bin:$PATH
 
-flacfile=metaflac.flac
+testdir="metaflac-test-files"
+flacfile="metaflac.flac"
 
 flac --help 1>/dev/null 2>/dev/null || die "ERROR can't find flac executable"
 metaflac --help 1>/dev/null 2>/dev/null || die "ERROR can't find metaflac executable"
@@ -65,276 +75,240 @@ run_metaflac ()
         fi
 }
 
+run_metaflac_silent ()
+{
+        if [ -z "$SILENT" ] ; then
+                run_metaflac $*
+        else
+                if [ x"$FLAC__TEST_WITH_VALGRIND" = xyes ] ; then
+                        valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --logfile-fd=4 metaflac $* 2>/dev/null 4>>test_metaflac.valgrind.log
+                else
+                        metaflac $* 2>/dev/null
+                fi
+        fi
+}
+
+check_flac ()
+{
+        run_flac --silent --test $flacfile || die "ERROR in $flacfile" 1>&2
+}
+
 echo "Generating stream..."
-if [ -f /bin/sh.exe ] ; then
-        inputfile=/bin/sh.exe
-elif [ -f /bin/sh ] ; then
-        inputfile=/bin/sh
-else
-        inputfile="$0"
-fi
-if run_flac --force --verify -0 --output-name=$flacfile --force-raw-format --endian=big --sign=signed --channels=1 --bps=8 --sample-rate=44100 $inputfile ; then
+bytes=80000
+if dd if=/dev/zero ibs=1 count=$bytes | flac --force --verify -0 --input-size=$bytes --output-name=$flacfile --force-raw-format --endian=big --sign=signed --channels=1 --bps=8 --sample-rate=8000 - ; then
         chmod +w $flacfile
 else
         die "ERROR during generation"
 fi
 
-check_exit ()
+check_flac
+
+echo
+
+filter ()
 {
-        exit_code=$?
-        [ $exit_code = 0 ] || die "ERROR, exit code = $exit_code"
+        # minor danger, changing vendor strings will change the length of the
+        # VORBIS_COMMENT block, but if we add "^  length: " to the patterns,
+        # we lose info about PADDING size that we need
+        grep -Ev '^  vendor string: |^  m..imum .....size: ' | sed -e 's/, stream_offset.*//'
 }
-
-check_flac ()
+metaflac_test ()
 {
-        run_flac --silent --test $flacfile || die "ERROR in $flacfile" 1>&2
+        case="$1"
+        desc="$2"
+        args="$3"
+        expect="$testdir/$case-expect.meta"
+        echo -n "test $case: $desc... "
+        run_metaflac $args $flacfile | filter > $testdir/out.meta || die "ERROR running metaflac"
+        diff -q -w $expect $testdir/out.meta 2>/dev/null || die "ERROR: metadata does not match expected $expect"
+        echo OK
 }
 
-check_flac
-
-(set -x && run_metaflac --list $flacfile)
-check_exit
+metaflac_test case00 "--list" "--list"
 
-(set -x &&
-run_metaflac \
-        --show-md5sum \
-        --show-min-blocksize \
-        --show-max-blocksize \
-        --show-min-framesize \
-        --show-max-framesize \
-        --show-sample-rate \
-        --show-channels \
-        --show-bps \
-        --show-total-samples \
-        $flacfile
-)
-check_exit
+metaflac_test case01 "STREAMINFO --show-* shortcuts" "
+        --show-md5sum
+        --show-min-blocksize
+        --show-max-blocksize
+        --show-min-framesize
+        --show-max-framesize
+        --show-sample-rate
+        --show-channels
+        --show-bps
+        --show-total-samples"
 
-(set -x && run_metaflac --preserve-modtime --add-padding=12345 $flacfile)
-check_exit
+run_metaflac --preserve-modtime --add-padding=12345 $flacfile
 check_flac
+metaflac_test case02 "--add-padding" "--list"
 
 # some flavors of /bin/sh (e.g. Darwin's) won't even handle quoted spaces, so we underscore:
-(set -x && run_metaflac --set-tag="ARTIST=The_artist_formerly_known_as_the_artist..." $flacfile)
-check_exit
+run_metaflac --set-tag="ARTIST=The_artist_formerly_known_as_the_artist..." $flacfile
 check_flac
+metaflac_test case03 "--set-tag=ARTIST" "--list"
 
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
-
-(set -x && run_metaflac --set-tag="ARTIST=Chuck_Woolery" $flacfile)
-check_exit
+run_metaflac --set-tag="ARTIST=Chuck_Woolery" $flacfile
 check_flac
+metaflac_test case04 "--set-tag=ARTIST" "--list"
 
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
-
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
-
-(set -x && run_metaflac --set-tag="ARTIST=Vern" $flacfile)
-check_exit
+run_metaflac --set-tag="ARTIST=Vern" $flacfile
 check_flac
+metaflac_test case05 "--set-tag=ARTIST" "--list"
 
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
-
-(set -x && run_metaflac --set-tag="TITLE=He_who_smelt_it_dealt_it" $flacfile)
-check_exit
+run_metaflac --set-tag="TITLE=He_who_smelt_it_dealt_it" $flacfile
 check_flac
+metaflac_test case06 "--set-tag=TITLE" "--list"
 
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
+metaflac_test case07 "--show-vendor-tag --show-tag=ARTIST" "--show-vendor-tag --show-tag=ARTIST"
 
-(set -x && run_metaflac --show-vendor-tag --show-tag=ARTIST $flacfile)
-check_exit
-
-(set -x && run_metaflac --remove-first-tag=ARTIST $flacfile)
-check_exit
+run_metaflac --remove-first-tag=ARTIST $flacfile
 check_flac
+metaflac_test case08 "--remove-first-tag=ARTIST" "--list"
 
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
-
-(set -x && run_metaflac --remove-tag=ARTIST $flacfile)
-check_exit
+run_metaflac --remove-tag=ARTIST $flacfile
 check_flac
+metaflac_test case09 "--remove-tag=ARTIST" "--list"
 
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
-
-(set -x && run_metaflac --list --block-number=0 $flacfile)
-check_exit
-
-(set -x && run_metaflac --list --block-number=1,2,999 $flacfile)
-check_exit
-
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT,PADDING $flacfile)
-check_exit
+metaflac_test case10 "--list --block-type=VORBIS_COMMENT" "--list --block-type=VORBIS_COMMENT"
+metaflac_test case11 "--list --block-number=0" "--list --block-number=0"
+metaflac_test case12 "--list --block-number=1,2,999" "--list --block-number=1,2,999"
+metaflac_test case13 "--list --block-type=VORBIS_COMMENT,PADDING" "--list --block-type=VORBIS_COMMENT,PADDING"
+metaflac_test case14 "--list --except-block-type=SEEKTABLE,VORBIS_COMMENT" "--list --except-block-type=SEEKTABLE,VORBIS_COMMENT"
+metaflac_test case15 "--list --except-block-type=STREAMINFO" "--list --except-block-type=STREAMINFO"
 
-(set -x && run_metaflac --list --except-block-type=SEEKTABLE,VORBIS_COMMENT $flacfile)
-check_exit
-
-(set -x && run_metaflac --add-padding=4321 $flacfile $flacfile)
-check_exit
+run_metaflac --add-padding=4321 $flacfile $flacfile
 check_flac
+metaflac_test case16 "--add-padding=4321 * 2" "--list"
 
-(set -x && run_metaflac --merge-padding $flacfile)
-check_exit
+run_metaflac --merge-padding $flacfile
 check_flac
+metaflac_test case17 "--merge-padding" "--list"
 
-(set -x && run_metaflac --add-padding=0 $flacfile)
-check_exit
+run_metaflac --add-padding=0 $flacfile
 check_flac
+metaflac_test case18 "--add-padding=0" "--list"
 
-(set -x && run_metaflac --sort-padding $flacfile)
-check_exit
+run_metaflac --sort-padding $flacfile
 check_flac
+metaflac_test case19 "--sort-padding" "--list"
 
-(set -x && run_metaflac --add-padding=0 $flacfile)
-check_exit
+run_metaflac --add-padding=0 $flacfile
 check_flac
+metaflac_test case20 "--add-padding=0" "--list"
 
-(set -x && run_metaflac --remove-all-tags $flacfile)
-check_exit
+run_metaflac --remove-all-tags $flacfile
 check_flac
+metaflac_test case21 "--remove-all-tags" "--list"
 
-(set -x && run_metaflac --remove --block-number=1,99 --dont-use-padding $flacfile)
-check_exit
+run_metaflac --remove --block-number=1,99 --dont-use-padding $flacfile
 check_flac
+metaflac_test case22 "--remove --block-number=1,99 --dont-use-padding" "--list"
 
-(set -x && run_metaflac --remove --block-number=99 --dont-use-padding $flacfile)
-check_exit
+run_metaflac --remove --block-number=99 --dont-use-padding $flacfile
 check_flac
+metaflac_test case23 "--remove --block-number=99 --dont-use-padding" "--list"
 
-(set -x && run_metaflac --remove --block-type=PADDING $flacfile)
-check_exit
+run_metaflac --remove --block-type=PADDING $flacfile
 check_flac
+metaflac_test case24 "--remove --block-type=PADDING" "--list"
 
-(set -x && run_metaflac --remove --block-type=PADDING --dont-use-padding $flacfile)
-check_exit
+run_metaflac --remove --block-type=PADDING --dont-use-padding $flacfile
 check_flac
+metaflac_test case25 "--remove --block-type=PADDING --dont-use-padding" "--list"
 
-(set -x && run_metaflac --add-padding=0 $flacfile $flacfile)
-check_exit
+run_metaflac --add-padding=0 $flacfile $flacfile
 check_flac
+metaflac_test case26 "--add-padding=0 * 2" "--list"
 
-(set -x && run_metaflac --remove --except-block-type=PADDING $flacfile)
-check_exit
+run_metaflac --remove --except-block-type=PADDING $flacfile
 check_flac
+metaflac_test case27 "--remove --except-block-type=PADDING" "--list"
 
-(set -x && run_metaflac --remove-all $flacfile)
-check_exit
+run_metaflac --remove-all $flacfile
 check_flac
+metaflac_test case28 "--remove-all" "--list"
 
-(set -x && run_metaflac --remove-all --dont-use-padding $flacfile)
-check_exit
+run_metaflac --remove-all --dont-use-padding $flacfile
 check_flac
+metaflac_test case29 "--remove-all --dont-use-padding" "--list"
 
-(set -x && run_metaflac --remove-all --dont-use-padding $flacfile)
-check_exit
+run_metaflac --remove-all --dont-use-padding $flacfile
 check_flac
+metaflac_test case30 "--remove-all --dont-use-padding" "--list"
 
-(set -x && run_metaflac --set-tag="f=0123456789abcdefghij" $flacfile)
-check_exit
+run_metaflac --set-tag="f=0123456789abcdefghij" $flacfile
 check_flac
-(set -x && run_metaflac --list --except-block-type=STREAMINFO $flacfile)
-check_exit
+metaflac_test case31 "--set-tag=..." "--list"
 
-(set -x && run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghi" $flacfile)
-check_exit
+run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghi" $flacfile
 check_flac
-(set -x && run_metaflac --list --except-block-type=STREAMINFO $flacfile)
-check_exit
+metaflac_test case32 "--remove-all-tags --set-tag=..." "--list"
 
-(set -x && run_metaflac --remove-all-tags --set-tag="f=0123456789abcde" $flacfile)
-check_exit
+run_metaflac --remove-all-tags --set-tag="f=0123456789abcde" $flacfile
 check_flac
-(set -x && run_metaflac --list --except-block-type=STREAMINFO $flacfile)
-check_exit
+metaflac_test case33 "--remove-all-tags --set-tag=..." "--list"
 
-(set -x && run_metaflac --remove-all-tags --set-tag="f=0" $flacfile)
-check_exit
+run_metaflac --remove-all-tags --set-tag="f=0" $flacfile
 check_flac
-(set -x && run_metaflac --list --except-block-type=STREAMINFO $flacfile)
-check_exit
+metaflac_test case34 "--remove-all-tags --set-tag=..." "--list"
 
-(set -x && run_metaflac --remove-all-tags --set-tag="f=0123456789" $flacfile)
-check_exit
+run_metaflac --remove-all-tags --set-tag="f=0123456789" $flacfile
 check_flac
-(set -x && run_metaflac --list --except-block-type=STREAMINFO $flacfile)
-check_exit
+metaflac_test case35 "--remove-all-tags --set-tag=..." "--list"
 
-(set -x && run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghi" $flacfile)
-check_exit
+run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghi" $flacfile
 check_flac
-(set -x && run_metaflac --list --except-block-type=STREAMINFO $flacfile)
-check_exit
+metaflac_test case36 "--remove-all-tags --set-tag=..." "--list"
 
-(set -x && run_metaflac --remove-all-tags --set-tag="f=0123456789" $flacfile)
-check_exit
+run_metaflac --remove-all-tags --set-tag="f=0123456789" $flacfile
 check_flac
-(set -x && run_metaflac --list --except-block-type=STREAMINFO $flacfile)
-check_exit
+metaflac_test case37 "--remove-all-tags --set-tag=..." "--list"
 
-(set -x && run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghij" $flacfile)
-check_exit
+run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghij" $flacfile
 check_flac
-(set -x && run_metaflac --list --except-block-type=STREAMINFO $flacfile)
-check_exit
+metaflac_test case38 "--remove-all-tags --set-tag=..." "--list"
 
-(set -x && echo "TITLE=Tittle" | run_metaflac --import-tags-from=- $flacfile)
-check_exit
+echo "TITLE=Tittle" | run_metaflac --import-tags-from=- $flacfile
 check_flac
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
+metaflac_test case39 "--import-tags-from=-" "--list"
 
 cat > vc.txt << EOF
 artist=Fartist
 artist=artits
 EOF
-(set -x && run_metaflac --import-tags-from=vc.txt $flacfile)
-check_exit
+run_metaflac --import-tags-from=vc.txt $flacfile
 check_flac
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
+metaflac_test case40 "--import-tags-from=[FILE]" "--list"
 
 rm vc.txt
 
+run_metaflac --add-replay-gain $flacfile
+check_flac
+metaflac_test case41 "--add-replay-gain" "--list"
+
+run_metaflac --remove-replay-gain $flacfile
+check_flac
+metaflac_test case42 "--remove-replay-gain" "--list"
+
 cs_in=cuesheets/good.000.cue
 cs_out=metaflac.cue
 cs_out2=metaflac2.cue
-(set -x && run_metaflac --import-cuesheet-from="$cs_in" $flacfile)
-check_exit
+run_metaflac --import-cuesheet-from="$cs_in" $flacfile
 check_flac
-(set -x && run_metaflac --export-cuesheet-to=$cs_out $flacfile)
-check_exit
-(set -x && run_metaflac --remove --block-type=CUESHEET $flacfile)
-check_exit
+metaflac_test case43 "--import-cuesheet-from" "--list"
+run_metaflac --export-cuesheet-to=$cs_out $flacfile
+run_metaflac --remove --block-type=CUESHEET $flacfile
 check_flac
-(set -x && run_metaflac --import-cuesheet-from=$cs_out $flacfile)
-check_exit
+metaflac_test case44 "--remove --block-type=CUESHEET" "--list"
+run_metaflac --import-cuesheet-from=$cs_out $flacfile
 check_flac
-(set -x && run_metaflac --export-cuesheet-to=$cs_out2 $flacfile)
-check_exit
+metaflac_test case45 "--import-cuesheet-from" "--list"
+run_metaflac --export-cuesheet-to=$cs_out2 $flacfile
 echo "comparing cuesheets:"
 diff $cs_out $cs_out2 || die "ERROR, cuesheets should be identical"
 echo identical
 
 rm -f $cs_out $cs_out2
 
-(set -x && run_metaflac --add-replay-gain $flacfile)
-check_exit
-check_flac
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
-
-(set -x && run_metaflac --remove-replay-gain $flacfile)
-check_exit
-check_flac
-(set -x && run_metaflac --list --block-type=VORBIS_COMMENT $flacfile)
-check_exit
-
 echo -n "Testing FLAC file with unknown metadata... "
 cp -p metaflac.flac.in $flacfile
 # remove the VORBIS_COMMENT block so vendor string changes don't interfere with the comparison:
@@ -342,4 +316,6 @@ run_metaflac --remove --block-type=VORBIS_COMMENT --dont-use-padding $flacfile
 cmp $flacfile metaflac.flac.ok || die "ERROR, $flacfile and metaflac.flac.ok differ"
 echo OK
 
+rm -f out.flac out.meta
+
 exit 0