Chris@50: #!/bin/bash Chris@50: Chris@50: mypath=`dirname $0` Chris@50: r=$mypath/../sonic-annotator Chris@50: Chris@50: infile1=$mypath/audio/3clicks8.wav Chris@50: infile2=$mypath/audio/6clicks8.wav Chris@50: Chris@50: outfile1=$mypath/audio/3clicks8_vamp_vamp-example-plugins_percussiononsets_onsets.csv Chris@50: outfile2=$mypath/audio/6clicks8_vamp_vamp-example-plugins_percussiononsets_onsets.csv Chris@50: Chris@50: infile1dot=$mypath/audio/3.clicks.8.wav Chris@50: outfile1dot=$mypath/audio/3.clicks.8_vamp_vamp-example-plugins_percussiononsets_onsets.csv Chris@50: Chris@50: outfile3=$mypath/audio/3clicks8_vamp_vamp-example-plugins_percussiononsets_onsets.csv Chris@50: outfile4=$mypath/audio/3clicks8_vamp_vamp-example-plugins_percussiononsets_detectionfunction.csv Chris@50: Chris@50: testplug=vamp:vamp-example-plugins:percussiononsets Chris@50: tmpcsv=$mypath/tmp_1_$$.csv Chris@50: Chris@50: trap "rm -f $tmpcsv $outfile1 $outfile2 $outfile3 $outfile4 $infile1dot $outfile1dot" 0 Chris@50: Chris@50: fail() { Chris@50: echo "Test failed: $1" Chris@50: exit 1 Chris@50: } Chris@50: Chris@50: transformpfx=$mypath/transforms/transforms-rdf-writer-percussiononsets Chris@50: Chris@50: check_csv() { Chris@50: test -f $1 || \ Chris@50: fail "Fails to write output to expected location $1 for $2" Chris@50: # every line must contain the same number of commas Chris@50: formats=`awk -F, '{ print NF; }' $1 | sort | uniq | wc | awk '{ print $1 }'` Chris@50: if [ "$formats" != "1" ]; then Chris@50: fail "Output is not consistently formatted comma-separated file for $2" Chris@50: fi Chris@50: rm -f $1 Chris@50: } Chris@50: Chris@50: Chris@50: ctx="onsets transform, one audio file, default CSV writer destination" Chris@50: Chris@50: rm -f $outfile1 Chris@50: Chris@50: $r -t $transformpfx-onsets.n3 -w csv $infile1 2>/dev/null || \ Chris@50: fail "Fails to run with $ctx" Chris@50: Chris@50: check_csv $outfile1 "$ctx" Chris@50: Chris@50: Chris@50: ctx="onsets transform, one audio file with dots in filename, default CSV writer destination" Chris@50: Chris@50: rm -f $outfile1 Chris@50: Chris@50: cp $infile1 $infile1dot Chris@50: Chris@50: $r -t $transformpfx-onsets.n3 -w csv $infile1dot 2>/dev/null || \ Chris@50: fail "Fails to run with $ctx" Chris@50: Chris@50: check_csv $outfile1dot "$ctx" Chris@50: Chris@50: rm -f $infile1dot $outfile1dot Chris@50: Chris@50: Chris@50: ctx="onsets and df transforms, one audio file, default CSV writer destination" Chris@50: Chris@50: rm -f $outfile1 Chris@50: Chris@50: $r -t $transformpfx-onsets.n3 -t $transformpfx-detectionfunction.n3 -w csv $infile1 2>/dev/null || \ Chris@50: fail "Fails to run with $ctx" Chris@50: Chris@50: check_csv $outfile1 "$ctx" Chris@50: Chris@50: Chris@50: ctx="onsets transform, two audio files, default CSV writer destination" Chris@50: Chris@50: rm -f $outfile1 Chris@50: rm -f $outfile2 Chris@50: Chris@50: $r -t $transformpfx-onsets.n3 -w csv $infile1 $infile2 2>/dev/null || \ Chris@50: fail "Fails to run with $ctx" Chris@50: Chris@50: check_csv $outfile1 "$ctx" Chris@50: check_csv $outfile2 "$ctx" Chris@50: Chris@50: Chris@50: ctx="onsets transform, two audio files, one-file CSV writer" Chris@50: Chris@50: $r -t $transformpfx-onsets.n3 -w csv --csv-one-file $tmpcsv $infile1 $infile2 2>/dev/null || \ Chris@50: fail "Fails to run with $ctx" Chris@50: Chris@50: check_csv $tmpcsv "$ctx" Chris@50: Chris@50: Chris@50: ctx="onsets transform, two audio files, stdout CSV writer" Chris@50: Chris@50: $r -t $transformpfx-onsets.n3 -w csv --csv-stdout $infile1 $infile2 2>/dev/null >$tmpcsv || \ Chris@50: fail "Fails to run with $ctx" Chris@50: Chris@50: check_csv $tmpcsv "$ctx" Chris@50: Chris@50: Chris@50: ctx="existing output file and no --csv-force" Chris@50: Chris@50: touch $outfile1 Chris@50: Chris@50: $r -t $transformpfx-onsets.n3 -w csv $infile1 2>/dev/null && \ Chris@50: fail "Fails by completing successfully when output file already exists (should refuse and bail out)" Chris@50: Chris@50: Chris@50: ctx="existing output file and --csv-force" Chris@50: Chris@50: touch $outfile1 Chris@50: Chris@50: $r -t $transformpfx-onsets.n3 -w csv --csv-force $infile1 2>/dev/null || \ Chris@50: fail "Fails to run with $ctx" Chris@50: Chris@50: check_csv $outfile1 "$ctx" Chris@50: Chris@50: Chris@50: exit 0