test_flac.sh
上传用户:wstnjxml
上传日期:2014-04-03
资源大小:7248k
文件大小:35k
源码类别:

Windows CE

开发平台:

C/C++

  1. #!/bin/sh
  2. #  FLAC - Free Lossless Audio Codec
  3. #  Copyright (C) 2001,2002,2003,2004,2005  Josh Coalson
  4. #
  5. #  This file is part the FLAC project.  FLAC is comprised of several
  6. #  components distributed under difference licenses.  The codec libraries
  7. #  are distributed under Xiph.Org's BSD-like license (see the file
  8. #  COPYING.Xiph in this distribution).  All other programs, libraries, and
  9. #  plugins are distributed under the GPL (see COPYING.GPL).  The documentation
  10. #  is distributed under the Gnu FDL (see COPYING.FDL).  Each file in the
  11. #  FLAC distribution contains at the top the terms under which it may be
  12. #  distributed.
  13. #
  14. #  Since this particular file is relevant to all components of FLAC,
  15. #  it may be distributed under the Xiph.Org license, which is the least
  16. #  restrictive of those mentioned above.  See the file COPYING.Xiph in this
  17. #  distribution.
  18. die ()
  19. {
  20. echo $* 1>&2
  21. exit 1
  22. }
  23. if [ x = x"$1" ] ; then 
  24. BUILD=debug
  25. else
  26. BUILD="$1"
  27. fi
  28. LD_LIBRARY_PATH=../src/libFLAC/.libs:$LD_LIBRARY_PATH
  29. LD_LIBRARY_PATH=../src/libOggFLAC/.libs:$LD_LIBRARY_PATH
  30. LD_LIBRARY_PATH=../src/share/grabbag/.libs:$LD_LIBRARY_PATH
  31. LD_LIBRARY_PATH=../src/share/getopt/.libs:$LD_LIBRARY_PATH
  32. LD_LIBRARY_PATH=../src/share/replaygain_analysis/.libs:$LD_LIBRARY_PATH
  33. LD_LIBRARY_PATH=../src/share/replaygain_synthesis/.libs:$LD_LIBRARY_PATH
  34. LD_LIBRARY_PATH=../src/share/utf8/.libs:$LD_LIBRARY_PATH
  35. LD_LIBRARY_PATH=../obj/$BUILD/lib:$LD_LIBRARY_PATH
  36. export LD_LIBRARY_PATH
  37. PATH=../src/flac:$PATH
  38. PATH=../src/metaflac:$PATH
  39. PATH=../src/test_streams:$PATH
  40. PATH=../obj/$BUILD/bin:$PATH
  41. flac --help 1>/dev/null 2>/dev/null || die "ERROR can't find flac executable"
  42. run_flac ()
  43. {
  44. if [ x"$FLAC__VALGRIND" = xyes ] ; then
  45. valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --logfile-fd=4 flac $* 4>>test_flac.valgrind.log
  46. else
  47. flac $*
  48. fi
  49. }
  50. run_metaflac ()
  51. {
  52. if [ x"$FLAC__VALGRIND" = xyes ] ; then
  53. valgrind --leak-check=yes --show-reachable=yes --num-callers=100 --logfile-fd=4 metaflac $* 4>>test_flac.valgrind.log
  54. else
  55. metaflac $*
  56. fi
  57. }
  58. if [ `env | grep -ic '^comspec='` != 0 ] ; then
  59. is_win=yes
  60. else
  61. is_win=no
  62. fi
  63. echo "Checking for --ogg support in flac..."
  64. 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
  65. has_ogg=yes;
  66. echo "flac --ogg works"
  67. else
  68. has_ogg=no;
  69. echo "flac --ogg doesn't work"
  70. fi
  71. echo "Generating streams..."
  72. if [ ! -f wacky1.wav ] ; then
  73. test_streams || die "ERROR during test_streams"
  74. fi
  75. ############################################################################
  76. # test that flac doesn't automatically overwrite files unless -f is used
  77. ############################################################################
  78. echo "Try encoding to a file that exists; should fail"
  79. cp wacky1.wav exist.wav
  80. touch exist.flac
  81. if run_flac --totally-silent -0 exist.wav ; then
  82. die "ERROR: it should have failed but didn't"
  83. else
  84. echo "OK, it failed as it should"
  85. fi
  86. echo "Try encoding with -f to a file that exists; should succeed"
  87. if run_flac --totally-silent -0 --force exist.wav ; then
  88. echo "OK, it succeeded as it should"
  89. else
  90. die "ERROR: it should have succeeded but didn't"
  91. fi
  92. echo "Try decoding to a file that exists; should fail"
  93. if run_flac --totally-silent -d exist.flac ; then
  94. die "ERROR: it should have failed but didn't"
  95. else
  96. echo "OK, it failed as it should"
  97. fi
  98. echo "Try decoding with -f to a file that exists; should succeed"
  99. if run_flac --totally-silent -d -f exist.flac ; then
  100. echo "OK, it succeeded as it should"
  101. else
  102. die "ERROR: it should have succeeded but didn't"
  103. fi
  104. rm -f exist.wav exist.flac
  105. ############################################################################
  106. # basic 'round-trip' tests of various kinds of streams
  107. ############################################################################
  108. rt_test_raw ()
  109. {
  110. f="$1"
  111. channels=`echo $f | awk -F- '{print $2}'`
  112. bytes_per_sample=`echo $f | awk -F- '{print $3}'`
  113. bps=`expr $bytes_per_sample '*' 8`
  114. echo -n "round-trip test ($f) encode... "
  115. run_flac --silent --force --verify --force-raw-format --endian=little --sign=signed --sample-rate=44100 --bps=$bps --channels=$channels $f -o rt.flac || die "ERROR"
  116. echo -n "decode... "
  117. run_flac --silent --force --decode --force-raw-format --endian=little --sign=signed -o rt.raw rt.flac || die "ERROR"
  118. echo -n "compare... "
  119. cmp $f rt.raw || die "ERROR: file mismatch"
  120. echo "OK"
  121. rm -f rt.flac rt.raw
  122. }
  123. rt_test_wav ()
  124. {
  125. f="$1"
  126. echo -n "round-trip test ($f) encode... "
  127. run_flac --silent --force --verify $f -o rt.flac || die "ERROR"
  128. echo -n "decode... "
  129. run_flac --silent --force --decode -o rt.wav rt.flac || die "ERROR"
  130. echo -n "compare... "
  131. cmp $f rt.wav || die "ERROR: file mismatch"
  132. echo "OK"
  133. rm -f rt.flac rt.wav
  134. }
  135. rt_test_aiff ()
  136. {
  137. f="$1"
  138. echo -n "round-trip test ($f) encode... "
  139. run_flac --silent --force --verify $f -o rt.flac || die "ERROR"
  140. echo -n "decode... "
  141. run_flac --silent --force --decode -o rt.aiff rt.flac || die "ERROR"
  142. echo -n "compare... "
  143. cmp $f rt.aiff || die "ERROR: file mismatch"
  144. echo "OK"
  145. rm -f rt.flac rt.aiff
  146. }
  147. for f in rt-*.raw ; do
  148. rt_test_raw $f
  149. done
  150. for f in rt-*.wav ; do
  151. rt_test_wav $f
  152. done
  153. for f in rt-*.aiff ; do
  154. rt_test_aiff $f
  155. done
  156. ############################################################################
  157. # test --skip and --until
  158. ############################################################################
  159. #
  160. # first make some chopped-up raw files
  161. #
  162. echo "abcdefghijklmnopqrstuvwxyz1234567890ABCDEFGHIJKLMN" > master.raw
  163. dddie="die ERROR: creating files for --skip/--until tests"
  164. dd if=master.raw ibs=1 count=50 of=50c.raw 2>/dev/null || $dddie
  165. dd if=master.raw ibs=1 skip=10 count=40 of=50c.skip10.raw 2>/dev/null || $dddie
  166. dd if=master.raw ibs=1 skip=11 count=39 of=50c.skip11.raw 2>/dev/null || $dddie
  167. dd if=master.raw ibs=1 skip=20 count=30 of=50c.skip20.raw 2>/dev/null || $dddie
  168. dd if=master.raw ibs=1 skip=30 count=20 of=50c.skip30.raw 2>/dev/null || $dddie
  169. dd if=master.raw ibs=1 skip=40 count=10 of=50c.skip40.raw 2>/dev/null || $dddie
  170. dd if=master.raw ibs=1 count=10 of=50c.until10.raw 2>/dev/null || $dddie
  171. dd if=master.raw ibs=1 count=20 of=50c.until20.raw 2>/dev/null || $dddie
  172. dd if=master.raw ibs=1 count=30 of=50c.until30.raw 2>/dev/null || $dddie
  173. dd if=master.raw ibs=1 count=39 of=50c.until39.raw 2>/dev/null || $dddie
  174. dd if=master.raw ibs=1 count=40 of=50c.until40.raw 2>/dev/null || $dddie
  175. dd if=master.raw ibs=1 skip=10 count=20 of=50c.skip10.until30.raw 2>/dev/null || $dddie
  176. dd if=master.raw ibs=1 skip=10 count=29 of=50c.skip10.until39.raw 2>/dev/null || $dddie
  177. dd if=master.raw ibs=1 skip=10 count=30 of=50c.skip10.until40.raw 2>/dev/null || $dddie
  178. dd if=master.raw ibs=1 skip=20 count=10 of=50c.skip20.until30.raw 2>/dev/null || $dddie
  179. dd if=master.raw ibs=1 skip=20 count=20 of=50c.skip20.until40.raw 2>/dev/null || $dddie
  180. wav_eopt="--silent --force --verify --lax"
  181. wav_dopt="--silent --force --decode"
  182. raw_eopt="$wav_eopt --force-raw-format --endian=big --sign=signed --sample-rate=10 --bps=8 --channels=1"
  183. raw_dopt="$wav_dopt --force-raw-format --endian=big --sign=signed"
  184. #
  185. # convert them to WAVE and AIFF files
  186. #
  187. convert_to_wav ()
  188. {
  189. run_flac $raw_eopt $1.raw || die "ERROR converting $1.raw to WAVE"
  190. run_flac $wav_dopt $1.flac || die "ERROR converting $1.raw to WAVE"
  191. }
  192. convert_to_wav 50c
  193. convert_to_wav 50c.skip10
  194. convert_to_wav 50c.skip11
  195. convert_to_wav 50c.skip20
  196. convert_to_wav 50c.skip30
  197. convert_to_wav 50c.skip40
  198. convert_to_wav 50c.until10
  199. convert_to_wav 50c.until20
  200. convert_to_wav 50c.until30
  201. convert_to_wav 50c.until39
  202. convert_to_wav 50c.until40
  203. convert_to_wav 50c.skip10.until30
  204. convert_to_wav 50c.skip10.until39
  205. convert_to_wav 50c.skip10.until40
  206. convert_to_wav 50c.skip20.until30
  207. convert_to_wav 50c.skip20.until40
  208. convert_to_aiff ()
  209. {
  210. run_flac $raw_eopt $1.raw || die "ERROR converting $1.raw to AIFF"
  211. run_flac $wav_dopt $1.flac -o $1.aiff || die "ERROR converting $1.raw to AIFF"
  212. }
  213. convert_to_aiff 50c
  214. convert_to_aiff 50c.skip10
  215. convert_to_aiff 50c.skip11
  216. convert_to_aiff 50c.skip20
  217. convert_to_aiff 50c.skip30
  218. convert_to_aiff 50c.skip40
  219. convert_to_aiff 50c.until10
  220. convert_to_aiff 50c.until20
  221. convert_to_aiff 50c.until30
  222. convert_to_aiff 50c.until39
  223. convert_to_aiff 50c.until40
  224. convert_to_aiff 50c.skip10.until30
  225. convert_to_aiff 50c.skip10.until39
  226. convert_to_aiff 50c.skip10.until40
  227. convert_to_aiff 50c.skip20.until30
  228. convert_to_aiff 50c.skip20.until40
  229. test_skip_until ()
  230. {
  231. in_fmt=$1
  232. out_fmt=$2
  233. [ "$in_fmt" = wav ] || [ "$in_fmt" = aiff ] || [ "$in_fmt" = raw ] || die "ERROR: internal error, bad 'in' format '$in_fmt'"
  234. [ "$out_fmt" = flac ] || [ "$out_fmt" = ogg ] || die "ERROR: internal error, bad 'out' format '$out_fmt'"
  235. if [ $in_fmt = raw ] ; then
  236. eopt="$raw_eopt"
  237. dopt="$raw_dopt"
  238. else
  239. eopt="$wav_eopt"
  240. dopt="$wav_dopt"
  241. fi
  242. if [ $out_fmt = ogg ] ; then
  243. eopt="--ogg $eopt"
  244. fi
  245. #
  246. # test --skip when encoding
  247. #
  248. desc="($in_fmt<->$out_fmt)"
  249. echo -n "testing --skip=# (encode) $desc... "
  250. run_flac $eopt --skip=10 -o z50c.skip10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  251. run_flac $dopt -o z50c.skip10.$in_fmt z50c.skip10.$out_fmt || die "ERROR decoding FLAC file $desc"
  252. cmp 50c.skip10.$in_fmt z50c.skip10.$in_fmt || die "ERROR: file mismatch for --skip=10 (encode) $desc"
  253. rm -f z50c.skip10.$out_fmt z50c.skip10.$in_fmt
  254. echo OK
  255. echo -n "testing --skip=mm:ss (encode) $desc... "
  256. run_flac $eopt --skip=0:01 -o z50c.skip0:01.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  257. run_flac $dopt -o z50c.skip0:01.$in_fmt z50c.skip0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
  258. cmp 50c.skip10.$in_fmt z50c.skip0:01.$in_fmt || die "ERROR: file mismatch for --skip=0:01 (encode) $desc"
  259. rm -f z50c.skip0:01.$out_fmt z50c.skip0:01.$in_fmt
  260. echo OK
  261. echo -n "testing --skip=mm:ss.sss (encode) $desc... "
  262. run_flac $eopt --skip=0:01.1001 -o z50c.skip0:01.1001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  263. run_flac $dopt -o z50c.skip0:01.1001.$in_fmt z50c.skip0:01.1001.$out_fmt || die "ERROR decoding FLAC file $desc"
  264. cmp 50c.skip11.$in_fmt z50c.skip0:01.1001.$in_fmt || die "ERROR: file mismatch for --skip=0:01.1001 (encode) $desc"
  265. rm -f z50c.skip0:01.1001.$out_fmt z50c.skip0:01.1001.$in_fmt
  266. echo OK
  267. #
  268. # test --skip when decoding
  269. #
  270. echo -n "testing --skip=# (decode) $desc... "
  271. run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  272. run_flac $dopt --skip=10 -o z50c.skip10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  273. cmp 50c.skip10.$in_fmt z50c.skip10.$in_fmt || die "ERROR: file mismatch for --skip=10 (decode) $desc"
  274. rm -f z50c.skip10.$in_fmt
  275. echo OK
  276. echo -n "testing --skip=mm:ss (decode) $desc... "
  277. run_flac $dopt --skip=0:01 -o z50c.skip0:01.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  278. cmp 50c.skip10.$in_fmt z50c.skip0:01.$in_fmt || die "ERROR: file mismatch for --skip=0:01 (decode) $desc"
  279. rm -f z50c.skip0:01.$in_fmt
  280. echo OK
  281. echo -n "testing --skip=mm:ss.sss (decode) $desc... "
  282. run_flac $dopt --skip=0:01.1001 -o z50c.skip0:01.1001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  283. cmp 50c.skip11.$in_fmt z50c.skip0:01.1001.$in_fmt || die "ERROR: file mismatch for --skip=0:01.1001 (decode) $desc"
  284. rm -f z50c.skip0:01.1001.$in_fmt
  285. echo OK
  286. rm -f z50c.$out_fmt
  287. #
  288. # test --until when encoding
  289. #
  290. echo -n "testing --until=# (encode) $desc... "
  291. run_flac $eopt --until=40 -o z50c.until40.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  292. run_flac $dopt -o z50c.until40.$in_fmt z50c.until40.$out_fmt || die "ERROR decoding FLAC file $desc"
  293. cmp 50c.until40.$in_fmt z50c.until40.$in_fmt || die "ERROR: file mismatch for --until=40 (encode) $desc"
  294. rm -f z50c.until40.$out_fmt z50c.until40.$in_fmt
  295. echo OK
  296. echo -n "testing --until=mm:ss (encode) $desc... "
  297. run_flac $eopt --until=0:04 -o z50c.until0:04.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  298. run_flac $dopt -o z50c.until0:04.$in_fmt z50c.until0:04.$out_fmt || die "ERROR decoding FLAC file $desc"
  299. cmp 50c.until40.$in_fmt z50c.until0:04.$in_fmt || die "ERROR: file mismatch for --until=0:04 (encode) $desc"
  300. rm -f z50c.until0:04.$out_fmt z50c.until0:04.$in_fmt
  301. echo OK
  302. echo -n "testing --until=mm:ss.sss (encode) $desc... "
  303. run_flac $eopt --until=0:03.9001 -o z50c.until0:03.9001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  304. run_flac $dopt -o z50c.until0:03.9001.$in_fmt z50c.until0:03.9001.$out_fmt || die "ERROR decoding FLAC file $desc"
  305. cmp 50c.until39.$in_fmt z50c.until0:03.9001.$in_fmt || die "ERROR: file mismatch for --until=0:03.9001 (encode) $desc"
  306. rm -f z50c.until0:03.9001.$out_fmt z50c.until0:03.9001.$in_fmt
  307. echo OK
  308. echo -n "testing --until=-# (encode) $desc... "
  309. run_flac $eopt --until=-10 -o z50c.until-10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  310. run_flac $dopt -o z50c.until-10.$in_fmt z50c.until-10.$out_fmt || die "ERROR decoding FLAC file $desc"
  311. cmp 50c.until40.$in_fmt z50c.until-10.$in_fmt || die "ERROR: file mismatch for --until=-10 (encode) $desc"
  312. rm -f z50c.until-10.$out_fmt z50c.until-10.$in_fmt
  313. echo OK
  314. echo -n "testing --until=-mm:ss (encode) $desc... "
  315. run_flac $eopt --until=-0:01 -o z50c.until-0:01.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  316. run_flac $dopt -o z50c.until-0:01.$in_fmt z50c.until-0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
  317. cmp 50c.until40.$in_fmt z50c.until-0:01.$in_fmt || die "ERROR: file mismatch for --until=-0:01 (encode) $desc"
  318. rm -f z50c.until-0:01.$out_fmt z50c.until-0:01.$in_fmt
  319. echo OK
  320. echo -n "testing --until=-mm:ss.sss (encode) $desc... "
  321. run_flac $eopt --until=-0:01.1001 -o z50c.until-0:01.1001.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  322. run_flac $dopt -o z50c.until-0:01.1001.$in_fmt z50c.until-0:01.1001.$out_fmt || die "ERROR decoding FLAC file $desc"
  323. cmp 50c.until39.$in_fmt z50c.until-0:01.1001.$in_fmt || die "ERROR: file mismatch for --until=-0:01.1001 (encode) $desc"
  324. rm -f z50c.until-0:01.1001.$out_fmt z50c.until-0:01.1001.$in_fmt
  325. echo OK
  326. #
  327. # test --until when decoding
  328. #
  329. run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  330. echo -n "testing --until=# (decode) $desc... "
  331. run_flac $dopt --until=40 -o z50c.until40.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  332. cmp 50c.until40.$in_fmt z50c.until40.$in_fmt || die "ERROR: file mismatch for --until=40 (decode) $desc"
  333. rm -f z50c.until40.$in_fmt
  334. echo OK
  335. echo -n "testing --until=mm:ss (decode) $desc... "
  336. run_flac $dopt --until=0:04 -o z50c.until0:04.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  337. cmp 50c.until40.$in_fmt z50c.until0:04.$in_fmt || die "ERROR: file mismatch for --until=0:04 (decode) $desc"
  338. rm -f z50c.until0:04.$in_fmt
  339. echo OK
  340. echo -n "testing --until=mm:ss.sss (decode) $desc... "
  341. run_flac $dopt --until=0:03.9001 -o z50c.until0:03.9001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  342. cmp 50c.until39.$in_fmt z50c.until0:03.9001.$in_fmt || die "ERROR: file mismatch for --until=0:03.9001 (decode) $desc"
  343. rm -f z50c.until0:03.9001.$in_fmt
  344. echo OK
  345. echo -n "testing --until=-# (decode) $desc... "
  346. run_flac $dopt --until=-10 -o z50c.until-10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  347. cmp 50c.until40.$in_fmt z50c.until-10.$in_fmt || die "ERROR: file mismatch for --until=-10 (decode) $desc"
  348. rm -f z50c.until-10.$in_fmt
  349. echo OK
  350. echo -n "testing --until=-mm:ss (decode) $desc... "
  351. run_flac $dopt --until=-0:01 -o z50c.until-0:01.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  352. cmp 50c.until40.$in_fmt z50c.until-0:01.$in_fmt || die "ERROR: file mismatch for --until=-0:01 (decode) $desc"
  353. rm -f z50c.until-0:01.$in_fmt
  354. echo OK
  355. echo -n "testing --until=-mm:ss.sss (decode) $desc... "
  356. run_flac $dopt --until=-0:01.1001 -o z50c.until-0:01.1001.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  357. cmp 50c.until39.$in_fmt z50c.until-0:01.1001.$in_fmt || die "ERROR: file mismatch for --until=-0:01.1001 (decode) $desc"
  358. rm -f z50c.until-0:01.1001.$in_fmt
  359. echo OK
  360. rm -f z50c.$out_fmt
  361. #
  362. # test --skip and --until when encoding
  363. #
  364. echo -n "testing --skip=10 --until=# (encode) $desc... "
  365. run_flac $eopt --skip=10 --until=40 -o z50c.skip10.until40.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  366. run_flac $dopt -o z50c.skip10.until40.$in_fmt z50c.skip10.until40.$out_fmt || die "ERROR decoding FLAC file $desc"
  367. cmp 50c.skip10.until40.$in_fmt z50c.skip10.until40.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=40 (encode) $desc"
  368. rm -f z50c.skip10.until40.$out_fmt z50c.skip10.until40.$in_fmt
  369. echo OK
  370. echo -n "testing --skip=10 --until=mm:ss (encode) $desc... "
  371. run_flac $eopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  372. run_flac $dopt -o z50c.skip10.until0:04.$in_fmt z50c.skip10.until0:04.$out_fmt || die "ERROR decoding FLAC file $desc"
  373. cmp 50c.skip10.until40.$in_fmt z50c.skip10.until0:04.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=0:04 (encode) $desc"
  374. rm -f z50c.skip10.until0:04.$out_fmt z50c.skip10.until0:04.$in_fmt
  375. echo OK
  376. echo -n "testing --skip=10 --until=mm:ss.sss (encode) $desc... "
  377. 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"
  378. run_flac $dopt -o z50c.skip10.until0:03.9001.$in_fmt z50c.skip10.until0:03.9001.$out_fmt || die "ERROR decoding FLAC file $desc"
  379. 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"
  380. rm -f z50c.skip10.until0:03.9001.$out_fmt z50c.skip10.until0:03.9001.$in_fmt
  381. echo OK
  382. echo -n "testing --skip=10 --until=+# (encode) $desc... "
  383. run_flac $eopt --skip=10 --until=+30 -o z50c.skip10.until+30.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  384. run_flac $dopt -o z50c.skip10.until+30.$in_fmt z50c.skip10.until+30.$out_fmt || die "ERROR decoding FLAC file $desc"
  385. cmp 50c.skip10.until40.$in_fmt z50c.skip10.until+30.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=+30 (encode) $desc"
  386. rm -f z50c.skip10.until+30.$out_fmt z50c.skip10.until+30.$in_fmt
  387. echo OK
  388. echo -n "testing --skip=10 --until=+mm:ss (encode) $desc... "
  389. 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"
  390. run_flac $dopt -o z50c.skip10.until+0:03.$in_fmt z50c.skip10.until+0:03.$out_fmt || die "ERROR decoding FLAC file $desc"
  391. 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"
  392. rm -f z50c.skip10.until+0:03.$out_fmt z50c.skip10.until+0:03.$in_fmt
  393. echo OK
  394. echo -n "testing --skip=10 --until=+mm:ss.sss (encode) $desc... "
  395. 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"
  396. 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"
  397. 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"
  398. rm -f z50c.skip10.until+0:02.9001.$out_fmt z50c.skip10.until+0:02.9001.$in_fmt
  399. echo OK
  400. echo -n "testing --skip=10 --until=-# (encode) $desc... "
  401. run_flac $eopt --skip=10 --until=-10 -o z50c.skip10.until-10.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  402. run_flac $dopt -o z50c.skip10.until-10.$in_fmt z50c.skip10.until-10.$out_fmt || die "ERROR decoding FLAC file $desc"
  403. cmp 50c.skip10.until40.$in_fmt z50c.skip10.until-10.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-10 (encode) $desc"
  404. rm -f z50c.skip10.until-10.$out_fmt z50c.skip10.until-10.$in_fmt
  405. echo OK
  406. echo -n "testing --skip=10 --until=-mm:ss (encode) $desc... "
  407. 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"
  408. run_flac $dopt -o z50c.skip10.until-0:01.$in_fmt z50c.skip10.until-0:01.$out_fmt || die "ERROR decoding FLAC file $desc"
  409. 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"
  410. rm -f z50c.skip10.until-0:01.$out_fmt z50c.skip10.until-0:01.$in_fmt
  411. echo OK
  412. echo -n "testing --skip=10 --until=-mm:ss.sss (encode) $desc... "
  413. 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"
  414. 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"
  415. 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"
  416. rm -f z50c.skip10.until-0:01.1001.$out_fmt z50c.skip10.until-0:01.1001.$in_fmt
  417. echo OK
  418. #
  419. # test --skip and --until when decoding
  420. #
  421. run_flac $eopt -o z50c.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  422. echo -n "testing --skip=10 --until=# (decode) $desc... "
  423. run_flac $dopt --skip=10 --until=40 -o z50c.skip10.until40.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  424. cmp 50c.skip10.until40.$in_fmt z50c.skip10.until40.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=40 (decode) $desc"
  425. rm -f z50c.skip10.until40.$in_fmt
  426. echo OK
  427. echo -n "testing --skip=10 --until=mm:ss (decode) $desc... "
  428. run_flac $dopt --skip=10 --until=0:04 -o z50c.skip10.until0:04.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  429. cmp 50c.skip10.until40.$in_fmt z50c.skip10.until0:04.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=0:04 (decode) $desc"
  430. rm -f z50c.skip10.until0:04.$in_fmt
  431. echo OK
  432. echo -n "testing --skip=10 --until=mm:ss.sss (decode) $desc... "
  433. 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"
  434. 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"
  435. rm -f z50c.skip10.until0:03.9001.$in_fmt
  436. echo OK
  437. echo -n "testing --skip=10 --until=-# (decode) $desc... "
  438. run_flac $dopt --skip=10 --until=-10 -o z50c.skip10.until-10.$in_fmt z50c.$out_fmt || die "ERROR decoding FLAC file $desc"
  439. cmp 50c.skip10.until40.$in_fmt z50c.skip10.until-10.$in_fmt || die "ERROR: file mismatch for --skip=10 --until=-10 (decode) $desc"
  440. rm -f z50c.skip10.until-10.$in_fmt
  441. echo OK
  442. echo -n "testing --skip=10 --until=-mm:ss (decode) $desc... "
  443. 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"
  444. 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"
  445. rm -f z50c.skip10.until-0:01.$in_fmt
  446. echo OK
  447. echo -n "testing --skip=10 --until=-mm:ss.sss (decode) $desc... "
  448. 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"
  449. 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"
  450. rm -f z50c.skip10.until-0:01.1001.$in_fmt
  451. echo OK
  452. rm -f z50c.$out_fmt
  453. }
  454. test_skip_until raw flac
  455. test_skip_until wav flac
  456. test_skip_until aiff flac
  457. if [ $has_ogg = "yes" ] ; then
  458. test_skip_until raw ogg
  459. test_skip_until wav ogg
  460. test_skip_until aiff ogg
  461. fi
  462. echo "testing seek extremes:"
  463. run_flac --verify --force --silent --force-raw-format --endian=big --sign=signed --sample-rate=44100 --bps=16 --channels=2 --blocksize=576 noise.raw || die "ERROR generating FLAC file"
  464. if [ $is_win = no ] ; then
  465. total_samples=`run_metaflac --show-total-samples noise.flac`
  466. [ $? = 0 ] || die "ERROR getting total sample count from noise.flac"
  467. else
  468. # some flavors of cygwin don't seem to treat the x0d as a word
  469. # separator, so we hard code it.  we'll just have to fix it later
  470. # if we change the way noise.flac is made.
  471. total_samples=393216
  472. fi
  473. echo -n "testing --skip=0... "
  474. run_flac $wav_dopt --skip=0 -o z.wav noise.flac || die "ERROR decoding FLAC file noise.flac"
  475. echo OK
  476. for delta in 2 1 ; do
  477. n=`expr $total_samples - $delta`
  478. echo -n "testing --skip=$n... "
  479. run_flac $wav_dopt --skip=$n -o z.wav noise.flac || die "ERROR decoding FLAC file noise.flac"
  480. echo OK
  481. done
  482. rm noise.flac z.wav
  483. ############################################################################
  484. # test --input-size
  485. ############################################################################
  486. #@@@@@@ cat will not work on old cygwin, need to fix
  487. if [ $is_win = no ] ; then
  488. echo -n "testing --input-size=50 --skip=10... "
  489. cat 50c.raw | run_flac $raw_eopt --input-size=50 --skip=10 -o z50c.skip10.flac - || die "ERROR generating FLAC file"
  490. run_flac $raw_dopt -o z50c.skip10.raw z50c.skip10.flac || die "ERROR decoding FLAC file"
  491. cmp 50c.skip10.raw z50c.skip10.raw || die "ERROR: file mismatch for --input-size=50 --skip=10"
  492. rm -f z50c.skip10.raw z50c.skip10.flac
  493. echo OK
  494. fi
  495. ############################################################################
  496. # test --skip and --until
  497. ############################################################################
  498. ############################################################################
  499. # test --cue
  500. ############################################################################
  501. #
  502. # create the cue sheet
  503. #
  504. cuesheet=cuetest.cue
  505. cat > $cuesheet << EOF
  506. CATALOG 1234567890123
  507. FILE "blah" WAVE
  508.   TRACK 01 AUDIO
  509.     INDEX 01 0
  510.     INDEX 02 10
  511.     INDEX 03 20
  512.   TRACK 02 AUDIO
  513.     INDEX 01 30
  514.   TRACK 04 AUDIO
  515.     INDEX 01 40
  516. EOF
  517. test_cue ()
  518. {
  519. in_fmt=$1
  520. out_fmt=$2
  521. [ "$in_fmt" = wav ] || [ "$in_fmt" = aiff ] || [ "$in_fmt" = raw ] || die "ERROR: internal error, bad 'in' format '$in_fmt'"
  522. [ "$out_fmt" = flac ] || [ "$out_fmt" = ogg ] || die "ERROR: internal error, bad 'out' format '$out_fmt'"
  523. if [ $in_fmt = raw ] ; then
  524. eopt="$raw_eopt"
  525. dopt="$raw_dopt"
  526. else
  527. eopt="$wav_eopt"
  528. dopt="$wav_dopt"
  529. fi
  530. if [ $out_fmt = ogg ] ; then
  531. eopt="--ogg $eopt"
  532. fi
  533. desc="($in_fmt<->$out_fmt)"
  534. #
  535. # for this we need just need just one FLAC file; --cue only works while decoding
  536. #
  537. run_flac $eopt --cuesheet=$cuesheet -o z50c.cue.$out_fmt 50c.$in_fmt || die "ERROR generating FLAC file $desc"
  538. # To make it easy to translate from cue point to sample numbers, the
  539. # file has a sample rate of 10 Hz and a cuesheet like so:
  540. #
  541. # TRACK 01, INDEX 01 : 0:00.00 -> sample 0
  542. # TRACK 01, INDEX 02 : 0:01.00 -> sample 10
  543. # TRACK 01, INDEX 03 : 0:02.00 -> sample 20
  544. # TRACK 02, INDEX 01 : 0:03.00 -> sample 30
  545. # TRACK 04, INDEX 01 : 0:04.00 -> sample 40
  546. #
  547. echo -n "testing --cue=- $desc... "
  548. run_flac $dopt -o z50c.cue.$in_fmt --cue=- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  549. cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=- $desc"
  550. rm -f z50c.cue.$in_fmt
  551. echo OK
  552. echo -n "testing --cue=1.0 $desc... "
  553. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  554. cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0 $desc"
  555. rm -f z50c.cue.$in_fmt
  556. echo OK
  557. echo -n "testing --cue=1.0- $desc... "
  558. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  559. cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0- $desc"
  560. rm -f z50c.cue.$in_fmt
  561. echo OK
  562. echo -n "testing --cue=1.1 $desc... "
  563. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  564. cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1 $desc"
  565. rm -f z50c.cue.$in_fmt
  566. echo OK
  567. echo -n "testing --cue=1.1- $desc... "
  568. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  569. cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1- $desc"
  570. rm -f z50c.cue.$in_fmt
  571. echo OK
  572. echo -n "testing --cue=1.2 $desc... "
  573. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  574. cmp 50c.skip10.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2 $desc"
  575. rm -f z50c.cue.$in_fmt
  576. echo OK
  577. echo -n "testing --cue=1.2- $desc... "
  578. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  579. cmp 50c.skip10.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2- $desc"
  580. rm -f z50c.cue.$in_fmt
  581. echo OK
  582. echo -n "testing --cue=1.4 $desc... "
  583. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  584. cmp 50c.skip20.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4 $desc"
  585. rm -f z50c.cue.$in_fmt
  586. echo OK
  587. echo -n "testing --cue=1.4- $desc... "
  588. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4- z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  589. cmp 50c.skip20.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4- $desc"
  590. rm -f z50c.cue.$in_fmt
  591. echo OK
  592. echo -n "testing --cue=-5.0 $desc... "
  593. run_flac $dopt -o z50c.cue.$in_fmt --cue=-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  594. cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-5.0 $desc"
  595. rm -f z50c.cue.$in_fmt
  596. echo OK
  597. echo -n "testing --cue=-4.1 $desc... "
  598. run_flac $dopt -o z50c.cue.$in_fmt --cue=-4.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  599. cmp 50c.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-4.1 $desc"
  600. rm -f z50c.cue.$in_fmt
  601. echo OK
  602. echo -n "testing --cue=-3.1 $desc... "
  603. run_flac $dopt -o z50c.cue.$in_fmt --cue=-3.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  604. cmp 50c.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-3.1 $desc"
  605. rm -f z50c.cue.$in_fmt
  606. echo OK
  607. echo -n "testing --cue=-1.4 $desc... "
  608. run_flac $dopt -o z50c.cue.$in_fmt --cue=-1.4 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  609. cmp 50c.until30.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=-1.4 $desc"
  610. rm -f z50c.cue.$in_fmt
  611. echo OK
  612. echo -n "testing --cue=1.0-5.0 $desc... "
  613. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.0-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  614. cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.0-5.0 $desc"
  615. rm -f z50c.cue.$in_fmt
  616. echo OK
  617. echo -n "testing --cue=1.1-5.0 $desc... "
  618. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.1-5.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  619. cmp 50c.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.1-5.0 $desc"
  620. rm -f z50c.cue.$in_fmt
  621. echo OK
  622. echo -n "testing --cue=1.2-4.1 $desc... "
  623. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.2-4.1 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  624. cmp 50c.skip10.until40.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.2-4.1 $desc"
  625. rm -f z50c.cue.$in_fmt
  626. echo OK
  627. echo -n "testing --cue=1.4-2.0 $desc... "
  628. run_flac $dopt -o z50c.cue.$in_fmt --cue=1.4-2.0 z50c.cue.$out_fmt || die "ERROR decoding FLAC file $desc"
  629. cmp 50c.skip20.until30.$in_fmt z50c.cue.$in_fmt || die "ERROR: file mismatch for --cue=1.4-2.0 $desc"
  630. rm -f z50c.cue.$in_fmt
  631. echo OK
  632. rm -f z50c.cue.$out_fmt
  633. }
  634. test_cue raw flac
  635. test_cue wav flac
  636. test_cue aiff flac
  637. if [ $has_ogg = "yes" ] ; then
  638. test_cue raw ogg
  639. test_cue wav ogg
  640. test_cue aiff ogg
  641. fi
  642. ############################################################################
  643. # test 'fixup' code that happens when a FLAC file with total_samples == 0
  644. # in the STREAMINFO block is converted to WAVE or AIFF, requiring the
  645. # decoder go back and fix up the chunk headers
  646. ############################################################################
  647. echo -n "WAVE fixup test... "
  648. echo -n "prepare... "
  649. convert_to_wav noise || die "ERROR creating reference WAVE"
  650. echo -n "encode... "
  651. # the pipe from 'cat' to 'flac' does not work on cygwin because of the EOF/
  652. # binary-mode stdin problem, so we use an undocumented option to metaflac to
  653. # set the total sample count to 0
  654. if [ $is_win = yes ] ; then
  655. run_flac $raw_eopt noise.raw -o fixup.flac || die "ERROR generating FLAC file"
  656. run_metaflac --set-total-samples=0 fixup.flac 2> /dev/null
  657. else
  658. cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
  659. fi
  660. echo -n "decode... "
  661. run_flac $wav_dopt fixup.flac -o fixup.wav || die "ERROR decoding FLAC file"
  662. echo -n "compare... "
  663. cmp noise.wav fixup.wav || die "ERROR: file mismatch"
  664. echo OK
  665. rm -f noise.wav fixup.wav fixup.flac
  666. echo -n "AIFF fixup test... "
  667. echo -n "prepare... "
  668. convert_to_aiff noise || die "ERROR creating reference AIFF"
  669. echo -n "encode... "
  670. # the pipe from 'cat' to 'flac' does not work on cygwin because of the EOF/
  671. # binary-mode stdin problem, so we use an undocumented option to metaflac to
  672. # set the total sample count to 0
  673. if [ $is_win = yes ] ; then
  674. run_flac $raw_eopt noise.raw -o fixup.flac || die "ERROR generating FLAC file"
  675. run_metaflac --set-total-samples=0 fixup.flac 2> /dev/null
  676. else
  677. cat noise.raw | run_flac $raw_eopt - -c > fixup.flac || die "ERROR generating FLAC file"
  678. fi
  679. echo -n "decode... "
  680. run_flac $wav_dopt fixup.flac -o fixup.aiff || die "ERROR decoding FLAC file"
  681. echo -n "compare... "
  682. cmp noise.aiff fixup.aiff || die "ERROR: file mismatch"
  683. echo OK
  684. rm -f noise.aiff fixup.aiff fixup.flac
  685. ############################################################################
  686. # multi-file tests
  687. ############################################################################
  688. echo "Generating multiple input files from noise..."
  689. run_flac --verify --force --silent --force-raw-format --endian=big --sign=signed --sample-rate=44100 --bps=16 --channels=2 noise.raw || die "ERROR generating FLAC file"
  690. run_flac --decode --force --silent noise.flac || die "ERROR generating WAVE file"
  691. rm -f noise.flac
  692. mv noise.wav file0.wav
  693. cp file0.wav file1.wav
  694. cp file1.wav file2.wav
  695. test_multifile ()
  696. {
  697. streamtype=$1
  698. sector_align=$2
  699. encode_options="$3"
  700. if [ $streamtype = ogg ] ; then
  701. suffix=ogg
  702. encode_options="$encode_options --ogg"
  703. else
  704. suffix=flac
  705. fi
  706. if [ $sector_align = sector_align ] ; then
  707. encode_options="$encode_options --sector-align"
  708. fi
  709. run_flac --force $encode_options file0.wav file1.wav file2.wav || die "ERROR"
  710. for n in 0 1 2 ; do
  711. mv file$n.$suffix file${n}x.$suffix
  712. done
  713. run_flac --force --decode file0x.$suffix file1x.$suffix file2x.$suffix || die "ERROR"
  714. if [ $sector_align != sector_align ] ; then
  715. for n in 0 1 2 ; do
  716. cmp file$n.wav file${n}x.wav || die "ERROR: file mismatch on file #$n"
  717. done
  718. fi
  719. for n in 0 1 2 ; do
  720. rm -f file${n}x.$suffix file${n}x.wav
  721. done
  722. }
  723. echo "Testing multiple files without verify..."
  724. test_multifile flac no_sector_align ""
  725. echo "Testing multiple files with verify..."
  726. test_multifile flac no_sector_align "--verify"
  727. echo "Testing multiple files with --sector-align, without verify..."
  728. test_multifile flac sector_align ""
  729. echo "Testing multiple files with --sector-align, with verify..."
  730. test_multifile flac sector_align "--verify"
  731. if [ $has_ogg = "yes" ] ; then
  732. echo "Testing multiple files with --ogg, without verify..."
  733. test_multifile ogg no_sector_align ""
  734. echo "Testing multiple files with --ogg, with verify..."
  735. test_multifile ogg no_sector_align "--verify"
  736. echo "Testing multiple files with --ogg and --sector-align, without verify..."
  737. test_multifile ogg sector_align ""
  738. echo "Testing multiple files with --ogg and --sector-align, with verify..."
  739. test_multifile sector_align ogg "--verify"
  740. echo "Testing multiple files with --ogg and --serial-number, with verify..."
  741. test_multifile ogg no_sector_align "--serial-number=321 --verify"
  742. fi