annotate src/libsndfile-1.0.27/tests/long_read_write_test.c @ 148:b4bfdf10c4b3

Update Win64 capnp builds to v0.6
author Chris Cannam <cannam@all-day-breakfast.com>
date Mon, 22 May 2017 18:56:49 +0100
parents cd6cdf86811e
children
rev   line source
cannam@125 1 /*
cannam@125 2 ** Copyright (C) 2015 Erik de Castro Lopo <erikd@mega-nerd.com>
cannam@125 3 **
cannam@125 4 ** This program is free software; you can redistribute it and/or modify
cannam@125 5 ** it under the terms of the GNU General Public License as published by
cannam@125 6 ** the Free Software Foundation; either version 2 of the License, or
cannam@125 7 ** (at your option) any later version.
cannam@125 8 **
cannam@125 9 ** This program is distributed in the hope that it will be useful,
cannam@125 10 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
cannam@125 11 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
cannam@125 12 ** GNU General Public License for more details.
cannam@125 13 **
cannam@125 14 ** You should have received a copy of the GNU General Public License
cannam@125 15 ** along with this program; if not, write to the Free Software
cannam@125 16 ** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
cannam@125 17 */
cannam@125 18
cannam@125 19 #include "sfconfig.h"
cannam@125 20
cannam@125 21 #include <stdio.h>
cannam@125 22 #include <stdlib.h>
cannam@125 23 #include <string.h>
cannam@125 24 #include <math.h>
cannam@125 25 #include <inttypes.h>
cannam@125 26
cannam@125 27 #if HAVE_UNISTD_H
cannam@125 28 #include <unistd.h>
cannam@125 29 #endif
cannam@125 30
cannam@125 31 #include <sndfile.h>
cannam@125 32
cannam@125 33 #include "dft_cmp.h"
cannam@125 34 #include "utils.h"
cannam@125 35
cannam@125 36 #define BUFFER_LENGTH 10000
cannam@125 37 #define SAMPLE_RATE 44010
cannam@125 38
cannam@125 39 static void short_lrw_test (const char *filename, int filetype, const short * output, int out_len) ;
cannam@125 40 static void int_lrw_test (const char *filename, int filetype, const int * output, int out_len) ;
cannam@125 41 static void float_lrw_test (const char *filename, int filetype, const float * output, int out_len) ;
cannam@125 42 static void double_lrw_test (const char *filename, int filetype, const double * output, int out_len) ;
cannam@125 43
cannam@125 44
cannam@125 45 static short short_data [BUFFER_LENGTH] ;
cannam@125 46 static int int_data [BUFFER_LENGTH] ;
cannam@125 47 static float float_data [BUFFER_LENGTH] ;
cannam@125 48 static double double_data [BUFFER_LENGTH] ;
cannam@125 49
cannam@125 50 int
cannam@125 51 main (int argc, char *argv [])
cannam@125 52 { int do_all ;
cannam@125 53 size_t k ;
cannam@125 54
cannam@125 55 if (argc != 2)
cannam@125 56 { printf ("Usage : %s <test>\n", argv [0]) ;
cannam@125 57 printf (" Where <test> is one of the following:\n") ;
cannam@125 58 printf (" alac - test CAF/ALAC file functions\n") ;
cannam@125 59 printf (" all - perform all tests\n") ;
cannam@125 60 exit (1) ;
cannam@125 61 } ;
cannam@125 62
cannam@125 63 for (k = 0 ; k < ARRAY_LEN (short_data) ; k++)
cannam@125 64 { int value = k / 32 ;
cannam@125 65 int_data [k] = (value & 1 ? -1 : 1) * value ;
cannam@125 66 short_data [k] = int_data [k] ;
cannam@125 67 float_data [k] = int_data [k] / 32000.0 ;
cannam@125 68 double_data [k] = int_data [k] / 32000.0 ;
cannam@125 69 }
cannam@125 70
cannam@125 71 do_all = ! strcmp (argv [1], "all") ;
cannam@125 72
cannam@125 73 if (do_all || strcmp (argv [1], "alac") == 0)
cannam@125 74 { short_lrw_test ("alac.caf", SF_FORMAT_CAF | SF_FORMAT_ALAC_16, short_data, ARRAY_LEN (short_data)) ;
cannam@125 75 int_lrw_test ("alac.caf", SF_FORMAT_CAF | SF_FORMAT_ALAC_32, int_data, ARRAY_LEN (int_data)) ;
cannam@125 76 float_lrw_test ("alac.caf", SF_FORMAT_CAF | SF_FORMAT_ALAC_32, float_data, ARRAY_LEN (float_data)) ;
cannam@125 77 double_lrw_test ("alac.caf", SF_FORMAT_CAF | SF_FORMAT_ALAC_32, double_data, ARRAY_LEN (double_data)) ;
cannam@125 78 } ;
cannam@125 79
cannam@125 80 return 0 ;
cannam@125 81 } /* main */
cannam@125 82
cannam@125 83 /*============================================================================================
cannam@125 84 * Here are the test functions.
cannam@125 85 */
cannam@125 86
cannam@125 87 static void
cannam@125 88 short_lrw_test (const char *filename, int filetype, const short * output, int out_len)
cannam@125 89 { SNDFILE *file ;
cannam@125 90 SF_INFO sfinfo ;
cannam@125 91 int k ;
cannam@125 92 short input [out_len] ;
cannam@125 93
cannam@125 94 print_test_name ("short_lrw_test", filename) ;
cannam@125 95
cannam@125 96 sfinfo.samplerate = SAMPLE_RATE ;
cannam@125 97 sfinfo.frames = out_len ;
cannam@125 98 sfinfo.channels = 1 ;
cannam@125 99 sfinfo.format = filetype ;
cannam@125 100
cannam@125 101 file = test_open_file_or_die (filename, SFM_WRITE, &sfinfo, SF_TRUE, __LINE__) ;
cannam@125 102
cannam@125 103 test_write_short_or_die (file, 0, output, out_len, __LINE__) ;
cannam@125 104
cannam@125 105 sf_close (file) ;
cannam@125 106
cannam@125 107 memset (input, 0, sizeof (input)) ;
cannam@125 108
cannam@125 109 file = test_open_file_or_die (filename, SFM_READ, &sfinfo, SF_TRUE, __LINE__) ;
cannam@125 110
cannam@125 111 exit_if_true (sfinfo.format != filetype, "\n\nLine %d: Returned format incorrect (0x%08X => 0x%08X).\n", __LINE__, filetype, sfinfo.format) ;
cannam@125 112 exit_if_true (sfinfo.frames < out_len, "\n\nLine %d: Incorrect number of frames in file (too short). (%" PRId64 " should be %d)\n", __LINE__, sfinfo.frames, DFT_DATA_LENGTH) ;
cannam@125 113 exit_if_true (sfinfo.channels != 1, "\n\nLine %d: Incorrect number of channels in file.\n", __LINE__) ;
cannam@125 114
cannam@125 115 check_log_buffer_or_die (file, __LINE__) ;
cannam@125 116
cannam@125 117 test_read_short_or_die (file, 0, input, out_len, __LINE__) ;
cannam@125 118
cannam@125 119 sf_close (file) ;
cannam@125 120
cannam@125 121 for (k = 0 ; k < out_len ; k++)
cannam@125 122 exit_if_true (input [k] != output [k],
cannam@125 123 "\n\nLine: %d: Error on input %d, expected %d, got %d\n", __LINE__, k, output [k], input [k]) ;
cannam@125 124
cannam@125 125 puts ("ok") ;
cannam@125 126 unlink (filename) ;
cannam@125 127
cannam@125 128 return ;
cannam@125 129 } /* short_lrw_test */
cannam@125 130
cannam@125 131 static void
cannam@125 132 int_lrw_test (const char *filename, int filetype, const int * output, int out_len)
cannam@125 133 { SNDFILE *file ;
cannam@125 134 SF_INFO sfinfo ;
cannam@125 135 int k ;
cannam@125 136 int input [out_len] ;
cannam@125 137
cannam@125 138 print_test_name ("int_lrw_test", filename) ;
cannam@125 139
cannam@125 140 sfinfo.samplerate = SAMPLE_RATE ;
cannam@125 141 sfinfo.frames = out_len ;
cannam@125 142 sfinfo.channels = 1 ;
cannam@125 143 sfinfo.format = filetype ;
cannam@125 144
cannam@125 145 file = test_open_file_or_die (filename, SFM_WRITE, &sfinfo, SF_TRUE, __LINE__) ;
cannam@125 146
cannam@125 147 test_write_int_or_die (file, 0, output, out_len, __LINE__) ;
cannam@125 148
cannam@125 149 sf_close (file) ;
cannam@125 150
cannam@125 151 memset (input, 0, sizeof (input)) ;
cannam@125 152
cannam@125 153 file = test_open_file_or_die (filename, SFM_READ, &sfinfo, SF_TRUE, __LINE__) ;
cannam@125 154
cannam@125 155 exit_if_true (sfinfo.format != filetype, "\n\nLine %d: Returned format incorrect (0x%08X => 0x%08X).\n", __LINE__, filetype, sfinfo.format) ;
cannam@125 156 exit_if_true (sfinfo.frames < out_len, "\n\nLine %d: Incorrect number of frames in file (too int). (%" PRId64 " should be %d)\n", __LINE__, sfinfo.frames, DFT_DATA_LENGTH) ;
cannam@125 157 exit_if_true (sfinfo.channels != 1, "\n\nLine %d: Incorrect number of channels in file.\n", __LINE__) ;
cannam@125 158
cannam@125 159 check_log_buffer_or_die (file, __LINE__) ;
cannam@125 160
cannam@125 161 test_read_int_or_die (file, 0, input, out_len, __LINE__) ;
cannam@125 162
cannam@125 163 sf_close (file) ;
cannam@125 164
cannam@125 165 for (k = 0 ; k < out_len ; k++)
cannam@125 166 exit_if_true (input [k] != output [k],
cannam@125 167 "\n\nLine: %d: Error on input %d, expected %d, got %d\n", __LINE__, k, output [k], input [k]) ;
cannam@125 168
cannam@125 169 puts ("ok") ;
cannam@125 170 unlink (filename) ;
cannam@125 171
cannam@125 172 return ;
cannam@125 173 } /* int_lrw_test */
cannam@125 174
cannam@125 175 static void
cannam@125 176 float_lrw_test (const char *filename, int filetype, const float * output, int out_len)
cannam@125 177 { SNDFILE *file ;
cannam@125 178 SF_INFO sfinfo ;
cannam@125 179 int k ;
cannam@125 180 float input [out_len] ;
cannam@125 181
cannam@125 182 print_test_name ("float_lrw_test", filename) ;
cannam@125 183
cannam@125 184 sfinfo.samplerate = SAMPLE_RATE ;
cannam@125 185 sfinfo.frames = out_len ;
cannam@125 186 sfinfo.channels = 1 ;
cannam@125 187 sfinfo.format = filetype ;
cannam@125 188
cannam@125 189 file = test_open_file_or_die (filename, SFM_WRITE, &sfinfo, SF_TRUE, __LINE__) ;
cannam@125 190
cannam@125 191 test_write_float_or_die (file, 0, output, out_len, __LINE__) ;
cannam@125 192
cannam@125 193 sf_close (file) ;
cannam@125 194
cannam@125 195 memset (input, 0, sizeof (input)) ;
cannam@125 196
cannam@125 197 file = test_open_file_or_die (filename, SFM_READ, &sfinfo, SF_TRUE, __LINE__) ;
cannam@125 198
cannam@125 199 exit_if_true (sfinfo.format != filetype, "\n\nLine %d: Returned format incorrect (0x%08X => 0x%08X).\n", __LINE__, filetype, sfinfo.format) ;
cannam@125 200 exit_if_true (sfinfo.frames < out_len, "\n\nLine %d: Incorrect number of frames in file (too float). (%" PRId64 " should be %d)\n", __LINE__, sfinfo.frames, DFT_DATA_LENGTH) ;
cannam@125 201 exit_if_true (sfinfo.channels != 1, "\n\nLine %d: Incorrect number of channels in file.\n", __LINE__) ;
cannam@125 202
cannam@125 203 check_log_buffer_or_die (file, __LINE__) ;
cannam@125 204
cannam@125 205 test_read_float_or_die (file, 0, input, out_len, __LINE__) ;
cannam@125 206
cannam@125 207 sf_close (file) ;
cannam@125 208
cannam@125 209 for (k = 0 ; k < out_len ; k++)
cannam@125 210 exit_if_true (fabs (input [k] - output [k]) > 0.00001,
cannam@125 211 "\n\nLine: %d: Error on input %d, expected %f, got %f\n", __LINE__, k, output [k], input [k]) ;
cannam@125 212
cannam@125 213 puts ("ok") ;
cannam@125 214 unlink (filename) ;
cannam@125 215
cannam@125 216 return ;
cannam@125 217 } /* float_lrw_test */
cannam@125 218
cannam@125 219 static void
cannam@125 220 double_lrw_test (const char *filename, int filetype, const double * output, int out_len)
cannam@125 221 { SNDFILE *file ;
cannam@125 222 SF_INFO sfinfo ;
cannam@125 223 int k ;
cannam@125 224 double input [out_len] ;
cannam@125 225
cannam@125 226 print_test_name ("double_lrw_test", filename) ;
cannam@125 227
cannam@125 228 sfinfo.samplerate = SAMPLE_RATE ;
cannam@125 229 sfinfo.frames = out_len ;
cannam@125 230 sfinfo.channels = 1 ;
cannam@125 231 sfinfo.format = filetype ;
cannam@125 232
cannam@125 233 file = test_open_file_or_die (filename, SFM_WRITE, &sfinfo, SF_TRUE, __LINE__) ;
cannam@125 234
cannam@125 235 test_write_double_or_die (file, 0, output, out_len, __LINE__) ;
cannam@125 236
cannam@125 237 sf_close (file) ;
cannam@125 238
cannam@125 239 memset (input, 0, sizeof (input)) ;
cannam@125 240
cannam@125 241 file = test_open_file_or_die (filename, SFM_READ, &sfinfo, SF_TRUE, __LINE__) ;
cannam@125 242
cannam@125 243 exit_if_true (sfinfo.format != filetype, "\n\nLine %d: Returned format incorrect (0x%08X => 0x%08X).\n", __LINE__, filetype, sfinfo.format) ;
cannam@125 244 exit_if_true (sfinfo.frames < out_len, "\n\nLine %d: Incorrect number of frames in file (too double). (%" PRId64 " should be %d)\n", __LINE__, sfinfo.frames, DFT_DATA_LENGTH) ;
cannam@125 245 exit_if_true (sfinfo.channels != 1, "\n\nLine %d: Incorrect number of channels in file.\n", __LINE__) ;
cannam@125 246
cannam@125 247 check_log_buffer_or_die (file, __LINE__) ;
cannam@125 248
cannam@125 249 test_read_double_or_die (file, 0, input, out_len, __LINE__) ;
cannam@125 250
cannam@125 251 sf_close (file) ;
cannam@125 252
cannam@125 253 for (k = 0 ; k < out_len ; k++)
cannam@125 254 exit_if_true (fabs (input [k] - output [k]) > 0.00001,
cannam@125 255 "\n\nLine: %d: Error on input %d, expected %f, got %f\n", __LINE__, k, output [k], input [k]) ;
cannam@125 256
cannam@125 257 puts ("ok") ;
cannam@125 258 unlink (filename) ;
cannam@125 259
cannam@125 260 return ;
cannam@125 261 } /* double_lrw_test */
cannam@125 262