limit subset further if sample rate is <=48kHz: max blocksize is 4608 and max LPC...
[flac.git] / test / test_metaflac.sh
1 #!/bin/sh
2
3 #  FLAC - Free Lossless Audio Codec
4 #  Copyright (C) 2002,2003,2004,2005,2006  Josh Coalson
5 #
6 #  This file is part the FLAC project.  FLAC is comprised of several
7 #  components distributed under difference licenses.  The codec libraries
8 #  are distributed under Xiph.Org's BSD-like license (see the file
9 #  COPYING.Xiph in this distribution).  All other programs, libraries, and
10 #  plugins are distributed under the GPL (see COPYING.GPL).  The documentation
11 #  is distributed under the Gnu FDL (see COPYING.FDL).  Each file in the
12 #  FLAC distribution contains at the top the terms under which it may be
13 #  distributed.
14 #
15 #  Since this particular file is relevant to all components of FLAC,
16 #  it may be distributed under the Xiph.Org license, which is the least
17 #  restrictive of those mentioned above.  See the file COPYING.Xiph in this
18 #  distribution.
19
20 die ()
21 {
22         echo $* 1>&2
23         exit 1
24 }
25
26 if [ x = x"$1" ] ; then
27         BUILD=debug
28 else
29         BUILD="$1"
30 fi
31
32 # change to 'false' to show all flac/metaflac output (useful for debugging)
33 if true ; then
34         SILENT='--silent'
35         TOTALLY_SILENT='--totally-silent'
36 else
37         SILENT=''
38         TOTALLY_SILENT=''
39 fi
40
41 LD_LIBRARY_PATH=`pwd`/../src/libFLAC/.libs:$LD_LIBRARY_PATH
42 LD_LIBRARY_PATH=`pwd`/../src/libOggFLAC/.libs:$LD_LIBRARY_PATH
43 LD_LIBRARY_PATH=`pwd`/../src/share/grabbag/.libs:$LD_LIBRARY_PATH
44 LD_LIBRARY_PATH=`pwd`/../src/share/getopt/.libs:$LD_LIBRARY_PATH
45 LD_LIBRARY_PATH=`pwd`/../src/share/replaygain_analysis/.libs:$LD_LIBRARY_PATH
46 LD_LIBRARY_PATH=`pwd`/../src/share/replaygain_synthesis/.libs:$LD_LIBRARY_PATH
47 LD_LIBRARY_PATH=`pwd`/../src/share/utf8/.libs:$LD_LIBRARY_PATH
48 LD_LIBRARY_PATH=`pwd`/../obj/$BUILD/lib:$LD_LIBRARY_PATH
49 export LD_LIBRARY_PATH
50 PATH=`pwd`/../src/flac:$PATH
51 PATH=`pwd`/../src/metaflac:$PATH
52 PATH=`pwd`/../obj/$BUILD/bin:$PATH
53
54 testdir="metaflac-test-files"
55 flacfile="metaflac.flac"
56
57 flac --help 1>/dev/null 2>/dev/null || die "ERROR can't find flac executable"
58 metaflac --help 1>/dev/null 2>/dev/null || die "ERROR can't find metaflac executable"
59
60 run_flac ()
61 {
62         if [ x"$FLAC__TEST_WITH_VALGRIND" = xyes ] ; then
63                 valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --logfile-fd=4 flac $* 4>>test_metaflac.valgrind.log
64         else
65                 flac $*
66         fi
67 }
68
69 run_metaflac ()
70 {
71         if [ x"$FLAC__TEST_WITH_VALGRIND" = xyes ] ; then
72                 valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --logfile-fd=4 metaflac $* 4>>test_metaflac.valgrind.log
73         else
74                 metaflac $*
75         fi
76 }
77
78 run_metaflac_silent ()
79 {
80         if [ -z "$SILENT" ] ; then
81                 run_metaflac $*
82         else
83                 if [ x"$FLAC__TEST_WITH_VALGRIND" = xyes ] ; then
84                         valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --logfile-fd=4 metaflac $* 2>/dev/null 4>>test_metaflac.valgrind.log
85                 else
86                         metaflac $* 2>/dev/null
87                 fi
88         fi
89 }
90
91 check_flac ()
92 {
93         run_flac --silent --test $flacfile || die "ERROR in $flacfile" 1>&2
94 }
95
96 echo "Generating stream..."
97 bytes=80000
98 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
99         chmod +w $flacfile
100 else
101         die "ERROR during generation"
102 fi
103
104 check_flac
105
106 echo
107
108 filter ()
109 {
110         # minor danger, changing vendor strings will change the length of the
111         # VORBIS_COMMENT block, but if we add "^  length: " to the patterns,
112         # we lose info about PADDING size that we need
113         # grep pattern 1: remove vendor string
114         # grep pattern 2: remove minimum/maximum frame and block size from STREAMINFO
115         # grep pattern 3: remove hexdump data from PICTURE metadata blocks
116         # sed pattern 1: remove stream offset values from SEEKTABLE points
117         grep -Ev '^  vendor string: |^  m..imum .....size: |^    0000[0-9a-fA-F][0-9a-fA-F][0-9a-fA-F][0-9a-fA-F]: ' | sed -e 's/, stream_offset.*//'
118 }
119 metaflac_test ()
120 {
121         case="$1"
122         desc="$2"
123         args="$3"
124         expect="$testdir/$case-expect.meta"
125         echo -n "test $case: $desc... "
126         run_metaflac $args $flacfile | filter > $testdir/out.meta || die "ERROR running metaflac"
127         diff -q -w $expect $testdir/out.meta 2>/dev/null || die "ERROR: metadata does not match expected $expect"
128         echo OK
129 }
130
131 metaflac_test case00 "--list" "--list"
132
133 metaflac_test case01 "STREAMINFO --show-* shortcuts" "
134         --show-md5sum
135         --show-min-blocksize
136         --show-max-blocksize
137         --show-min-framesize
138         --show-max-framesize
139         --show-sample-rate
140         --show-channels
141         --show-bps
142         --show-total-samples"
143
144 run_metaflac --preserve-modtime --add-padding=12345 $flacfile
145 check_flac
146 metaflac_test case02 "--add-padding" "--list"
147
148 # some flavors of /bin/sh (e.g. Darwin's) won't even handle quoted spaces, so we underscore:
149 run_metaflac --set-tag="ARTIST=The_artist_formerly_known_as_the_artist..." $flacfile
150 check_flac
151 metaflac_test case03 "--set-tag=ARTIST" "--list"
152
153 run_metaflac --set-tag="ARTIST=Chuck_Woolery" $flacfile
154 check_flac
155 metaflac_test case04 "--set-tag=ARTIST" "--list"
156
157 run_metaflac --set-tag="ARTIST=Vern" $flacfile
158 check_flac
159 metaflac_test case05 "--set-tag=ARTIST" "--list"
160
161 run_metaflac --set-tag="TITLE=He_who_smelt_it_dealt_it" $flacfile
162 check_flac
163 metaflac_test case06 "--set-tag=TITLE" "--list"
164
165 metaflac_test case07 "--show-vendor-tag --show-tag=ARTIST" "--show-vendor-tag --show-tag=ARTIST"
166
167 run_metaflac --remove-first-tag=ARTIST $flacfile
168 check_flac
169 metaflac_test case08 "--remove-first-tag=ARTIST" "--list"
170
171 run_metaflac --remove-tag=ARTIST $flacfile
172 check_flac
173 metaflac_test case09 "--remove-tag=ARTIST" "--list"
174
175 metaflac_test case10 "--list --block-type=VORBIS_COMMENT" "--list --block-type=VORBIS_COMMENT"
176 metaflac_test case11 "--list --block-number=0" "--list --block-number=0"
177 metaflac_test case12 "--list --block-number=1,2,999" "--list --block-number=1,2,999"
178 metaflac_test case13 "--list --block-type=VORBIS_COMMENT,PADDING" "--list --block-type=VORBIS_COMMENT,PADDING"
179 metaflac_test case14 "--list --except-block-type=SEEKTABLE,VORBIS_COMMENT" "--list --except-block-type=SEEKTABLE,VORBIS_COMMENT"
180 metaflac_test case15 "--list --except-block-type=STREAMINFO" "--list --except-block-type=STREAMINFO"
181
182 run_metaflac --add-padding=4321 $flacfile $flacfile
183 check_flac
184 metaflac_test case16 "--add-padding=4321 * 2" "--list"
185
186 run_metaflac --merge-padding $flacfile
187 check_flac
188 metaflac_test case17 "--merge-padding" "--list"
189
190 run_metaflac --add-padding=0 $flacfile
191 check_flac
192 metaflac_test case18 "--add-padding=0" "--list"
193
194 run_metaflac --sort-padding $flacfile
195 check_flac
196 metaflac_test case19 "--sort-padding" "--list"
197
198 run_metaflac --add-padding=0 $flacfile
199 check_flac
200 metaflac_test case20 "--add-padding=0" "--list"
201
202 run_metaflac --remove-all-tags $flacfile
203 check_flac
204 metaflac_test case21 "--remove-all-tags" "--list"
205
206 run_metaflac --remove --block-number=1,99 --dont-use-padding $flacfile
207 check_flac
208 metaflac_test case22 "--remove --block-number=1,99 --dont-use-padding" "--list"
209
210 run_metaflac --remove --block-number=99 --dont-use-padding $flacfile
211 check_flac
212 metaflac_test case23 "--remove --block-number=99 --dont-use-padding" "--list"
213
214 run_metaflac --remove --block-type=PADDING $flacfile
215 check_flac
216 metaflac_test case24 "--remove --block-type=PADDING" "--list"
217
218 run_metaflac --remove --block-type=PADDING --dont-use-padding $flacfile
219 check_flac
220 metaflac_test case25 "--remove --block-type=PADDING --dont-use-padding" "--list"
221
222 run_metaflac --add-padding=0 $flacfile $flacfile
223 check_flac
224 metaflac_test case26 "--add-padding=0 * 2" "--list"
225
226 run_metaflac --remove --except-block-type=PADDING $flacfile
227 check_flac
228 metaflac_test case27 "--remove --except-block-type=PADDING" "--list"
229
230 run_metaflac --remove-all $flacfile
231 check_flac
232 metaflac_test case28 "--remove-all" "--list"
233
234 run_metaflac --remove-all --dont-use-padding $flacfile
235 check_flac
236 metaflac_test case29 "--remove-all --dont-use-padding" "--list"
237
238 run_metaflac --remove-all --dont-use-padding $flacfile
239 check_flac
240 metaflac_test case30 "--remove-all --dont-use-padding" "--list"
241
242 run_metaflac --set-tag="f=0123456789abcdefghij" $flacfile
243 check_flac
244 metaflac_test case31 "--set-tag=..." "--list"
245
246 run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghi" $flacfile
247 check_flac
248 metaflac_test case32 "--remove-all-tags --set-tag=..." "--list"
249
250 run_metaflac --remove-all-tags --set-tag="f=0123456789abcde" $flacfile
251 check_flac
252 metaflac_test case33 "--remove-all-tags --set-tag=..." "--list"
253
254 run_metaflac --remove-all-tags --set-tag="f=0" $flacfile
255 check_flac
256 metaflac_test case34 "--remove-all-tags --set-tag=..." "--list"
257
258 run_metaflac --remove-all-tags --set-tag="f=0123456789" $flacfile
259 check_flac
260 metaflac_test case35 "--remove-all-tags --set-tag=..." "--list"
261
262 run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghi" $flacfile
263 check_flac
264 metaflac_test case36 "--remove-all-tags --set-tag=..." "--list"
265
266 run_metaflac --remove-all-tags --set-tag="f=0123456789" $flacfile
267 check_flac
268 metaflac_test case37 "--remove-all-tags --set-tag=..." "--list"
269
270 run_metaflac --remove-all-tags --set-tag="f=0123456789abcdefghij" $flacfile
271 check_flac
272 metaflac_test case38 "--remove-all-tags --set-tag=..." "--list"
273
274 echo "TITLE=Tittle" | run_metaflac --import-tags-from=- $flacfile
275 check_flac
276 metaflac_test case39 "--import-tags-from=-" "--list"
277
278 cat > vc.txt << EOF
279 artist=Fartist
280 artist=artits
281 EOF
282 run_metaflac --import-tags-from=vc.txt $flacfile
283 check_flac
284 metaflac_test case40 "--import-tags-from=[FILE]" "--list"
285
286 rm vc.txt
287
288 run_metaflac --add-replay-gain $flacfile
289 check_flac
290 metaflac_test case41 "--add-replay-gain" "--list"
291
292 run_metaflac --remove-replay-gain $flacfile
293 check_flac
294 metaflac_test case42 "--remove-replay-gain" "--list"
295
296 # CUESHEET blocks
297 cs_in=cuesheets/good.000.cue
298 cs_out=metaflac.cue
299 cs_out2=metaflac2.cue
300 run_metaflac --import-cuesheet-from="$cs_in" $flacfile
301 check_flac
302 metaflac_test case43 "--import-cuesheet-from" "--list"
303 run_metaflac --export-cuesheet-to=$cs_out $flacfile
304 run_metaflac --remove --block-type=CUESHEET $flacfile
305 check_flac
306 metaflac_test case44 "--remove --block-type=CUESHEET" "--list"
307 run_metaflac --import-cuesheet-from=$cs_out $flacfile
308 check_flac
309 metaflac_test case45 "--import-cuesheet-from" "--list"
310 run_metaflac --export-cuesheet-to=$cs_out2 $flacfile
311 echo "comparing cuesheets:"
312 diff $cs_out $cs_out2 || die "ERROR, cuesheets should be identical"
313 echo identical
314
315 rm -f $cs_out $cs_out2
316
317 # PICTURE blocks
318 ncase=46
319 for f in \
320         0.gif \
321         1.gif \
322         2.gif \
323 ; do
324         run_metaflac --import-picture="|image/gif|$f||pictures/$f" $flacfile
325         check_flac
326         metaflac_test "case$ncase" "--import-picture" "--list"
327         ncase=`expr $ncase + 1`
328 done
329 for f in \
330         0.jpg \
331         4.jpg \
332 ; do
333         run_metaflac --import-picture="4|image/jpeg|$f||pictures/$f" $flacfile
334         check_flac
335         metaflac_test "case$ncase" "--import-picture" "--list"
336         ncase=`expr $ncase + 1`
337 done
338 for f in \
339         0.png \
340         1.png \
341         2.png \
342         3.png \
343         4.png \
344         5.png \
345         6.png \
346         7.png \
347         8.png \
348 ; do
349         run_metaflac --import-picture="5|image/png|$f||pictures/$f" $flacfile
350         check_flac
351         metaflac_test "case$ncase" "--import-picture" "--list"
352         ncase=`expr $ncase + 1`
353 done
354 [ $ncase = 60 ] || die "expected case# to be 60"
355 run_metaflac --remove --block-type=PICTURE $flacfile
356 check_flac
357 metaflac_test case60 "--remove --block-type=PICTURE" "--list"
358 run_metaflac --import-picture="1|image/png|standard_icon|32x32x24|pictures/0.png" $flacfile
359 check_flac
360 metaflac_test case61 "--import-picture" "--list"
361 run_metaflac --import-picture="2|image/png|icon|64x64x24|pictures/1.png" $flacfile
362 check_flac
363 metaflac_test case62 "--import-picture" "--list"
364
365 # UNKNOWN blocks
366 echo -n "Testing FLAC file with unknown metadata... "
367 cp -p metaflac.flac.in $flacfile
368 # remove the VORBIS_COMMENT block so vendor string changes don't interfere with the comparison:
369 run_metaflac --remove --block-type=VORBIS_COMMENT --dont-use-padding $flacfile
370 cmp $flacfile metaflac.flac.ok || die "ERROR, $flacfile and metaflac.flac.ok differ"
371 echo OK
372
373 rm -f $testdir/out.flac $testdir/out.meta
374
375 exit 0