view tests/test-csv-writer/test-csv-writer.sh @ 271:7b3a80021b7c piper-nopiper

Add MAD_BUFFER_GUARD padding at end of mp3 buffer, in order to ensure last frame is decoded successfully (otherwise the decoded audio is truncated). Another thing learned from madplay.
author Chris Cannam
date Thu, 24 Nov 2016 17:06:31 +0000
parents e8f2f530c091
children
line wrap: on
line source
#!/bin/bash

. ../include.sh

infile=$audiopath/20sec-silence.wav
tmpcsv=$mypath/tmp_1_$$.csv

trap "rm -f $tmpcsv" 0

for output in notes-regions curve-vsr grid-oss; do

    flag=""

    $r -d "$testplug:$output" -w csv --csv-stdout "$infile" 2>/dev/null > "$tmpcsv" || \
	fail "Failed to run for plugin $testplug with output $output and no additional flags"

    csvcompare "$tmpcsv" "$mypath/expected/$output-no-flags.csv" || \
	faildiff "Output differs from expected for output $output and no additional flags" "$tmpcsv" "$mypath/expected/$output-no-flags.csv"

    flag=sample-timing

    $r -d "$testplug:$output" -w csv --csv-$flag --csv-stdout "$infile" 2>/dev/null > "$tmpcsv" || \
	fail "Failed to run for plugin $testplug with output $output and $flag flag"

    csvcompare "$tmpcsv" "$mypath/expected/$output-$flag.csv" || \
	faildiff "Output differs from expected for output $output and $flag flag" "$tmpcsv" "$mypath/expected/$output-$flag.csv"

    flag=fill-ends

    $r -d "$testplug:$output" -w csv --csv-$flag --csv-stdout "$infile" 2>/dev/null > "$tmpcsv" || \
	fail "Failed to run for plugin $testplug with output $output and $flag flag"

    csvcompare "$tmpcsv" "$mypath/expected/$output-$flag.csv" || \
	faildiff "Output differs from expected for output $output and $flag flag" "$tmpcsv" "$mypath/expected/$output-$flag.csv"

    flag=end-times

    $r -d "$testplug:$output" -w csv --csv-$flag --csv-stdout "$infile" 2>/dev/null > "$tmpcsv" || \
	fail "Failed to run for plugin $testplug with output $output and $flag flag"

    csvcompare "$tmpcsv" "$mypath/expected/$output-$flag.csv" || \
	faildiff "Output differs from expected for output $output and $flag flag" "$tmpcsv" "$mypath/expected/$output-$flag.csv"

    flag=separator

    $r -d "$testplug:$output" -w csv --csv-$flag '@' --csv-stdout "$infile" 2>/dev/null > "$tmpcsv" || \
	fail "Failed to run for plugin $testplug with output $output and $flag flag"

    csvcompare "$tmpcsv" "$mypath/expected/$output-$flag.csv" || \
	faildiff "Output differs from expected for output $output and $flag flag" "$tmpcsv" "$mypath/expected/$output-$flag.csv"

    flag=all

    $r -d "$testplug:$output" -w csv --csv-sample-timing --csv-fill-ends --csv-end-times --csv-separator '@' --csv-stdout "$infile" 2>/dev/null > "$tmpcsv" || \
	fail "Failed to run for plugin $testplug with output $output and all flags"

    csvcompare "$tmpcsv" "$mypath/expected/$output-$flag.csv" || \
	faildiff "Output differs from expected for output $output and all flags" "$tmpcsv" "$mypath/expected/$output-$flag.csv"

done

for output in grid-oss; do
    for digits in 0 6 2; do

	$r -d "$testplug:$output" -w csv --csv-stdout --csv-digits "$digits" "$infile" 2>/dev/null > "$tmpcsv" || \
	    fail "Failed to run for plugin $testplug with output $output and digits $digits"

	# no fuzz here
	cmp -s "$tmpcsv" "$mypath/expected/$output-$digits.csv" || \
	    faildiff "Output differs from expected for CSV writer with output $output and digits $digits" "$tmpcsv" "$mypath/expected/$output-$digits.csv"

    done
done

exit 0