annotate src/libsamplerate-0.1.9/tests/misc_test.c @ 149:279b18cc7785

Update Win32 capnp builds to v0.6
author Chris Cannam <cannam@all-day-breakfast.com>
date Tue, 23 May 2017 09:16:54 +0100
parents 4a7071416412
children
rev   line source
cannam@126 1 /*
cannam@126 2 ** Copyright (c) 2002-2016, Erik de Castro Lopo <erikd@mega-nerd.com>
cannam@126 3 ** All rights reserved.
cannam@126 4 **
cannam@126 5 ** This code is released under 2-clause BSD license. Please see the
cannam@126 6 ** file at : https://github.com/erikd/libsamplerate/blob/master/COPYING
cannam@126 7 */
cannam@126 8
cannam@126 9 #include <stdio.h>
cannam@126 10 #include <stdlib.h>
cannam@126 11 #include <string.h>
cannam@126 12
cannam@126 13 #include <samplerate.h>
cannam@126 14
cannam@126 15 #include "util.h"
cannam@126 16
cannam@126 17 static void name_test (void) ;
cannam@126 18 static void error_test (void) ;
cannam@126 19 static void src_ratio_test (void) ;
cannam@126 20 static void zero_input_test (int converter) ;
cannam@126 21
cannam@126 22 int
cannam@126 23 main (void)
cannam@126 24 {
cannam@126 25 puts ("") ;
cannam@126 26
cannam@126 27 printf (" version : %s\n\n", src_get_version ()) ;
cannam@126 28
cannam@126 29 /* Current max converter is SRC_LINEAR. */
cannam@126 30 name_test () ;
cannam@126 31
cannam@126 32 error_test () ;
cannam@126 33
cannam@126 34 src_ratio_test () ;
cannam@126 35
cannam@126 36 zero_input_test (SRC_ZERO_ORDER_HOLD) ;
cannam@126 37 zero_input_test (SRC_LINEAR) ;
cannam@126 38 zero_input_test (SRC_SINC_FASTEST) ;
cannam@126 39
cannam@126 40 puts ("") ;
cannam@126 41 return 0 ;
cannam@126 42 } /* main */
cannam@126 43
cannam@126 44 static void
cannam@126 45 name_test (void)
cannam@126 46 { const char *name ;
cannam@126 47 int k = 0 ;
cannam@126 48
cannam@126 49 puts (" name_test :") ;
cannam@126 50
cannam@126 51 while (1)
cannam@126 52 { name = src_get_name (k) ;
cannam@126 53 if (name == NULL)
cannam@126 54 break ;
cannam@126 55 printf ("\tName %d : %s\n", k, name) ;
cannam@126 56 printf ("\tDesc %d : %s\n", k, src_get_description (k)) ;
cannam@126 57 k ++ ;
cannam@126 58 } ;
cannam@126 59
cannam@126 60 puts ("") ;
cannam@126 61
cannam@126 62 return ;
cannam@126 63 } /* name_test */
cannam@126 64
cannam@126 65 /*------------------------------------------------------------------------------
cannam@126 66 */
cannam@126 67
cannam@126 68 typedef struct
cannam@126 69 { double ratio ;
cannam@126 70 int should_pass ;
cannam@126 71 } RATIO_TEST ;
cannam@126 72
cannam@126 73 static RATIO_TEST ratio_test [] =
cannam@126 74 { { 1.0 / 256.1, 0 },
cannam@126 75 { 1.0 / 256.0, 1 },
cannam@126 76 { 1.0, 1 },
cannam@126 77 { 256.0, 1 },
cannam@126 78 { 256.1, 0 },
cannam@126 79 { -1.0, 0 }
cannam@126 80 } ;
cannam@126 81
cannam@126 82 static void
cannam@126 83 src_ratio_test (void)
cannam@126 84 { int k ;
cannam@126 85
cannam@126 86 puts (" src_ratio_test (SRC ratio must be in range [1/256, 256]):" ) ;
cannam@126 87
cannam@126 88
cannam@126 89 for (k = 0 ; k < ARRAY_LEN (ratio_test) ; k++)
cannam@126 90 { if (ratio_test [k].should_pass && src_is_valid_ratio (ratio_test [k].ratio) == 0)
cannam@126 91 { printf ("\n\nLine %d : SRC ratio %f should have passed.\n\n", __LINE__, ratio_test [k].ratio) ;
cannam@126 92 exit (1) ;
cannam@126 93 } ;
cannam@126 94 if (! ratio_test [k].should_pass && src_is_valid_ratio (ratio_test [k].ratio) != 0)
cannam@126 95 { printf ("\n\nLine %d : SRC ratio %f should not have passed.\n\n", __LINE__, ratio_test [k].ratio) ;
cannam@126 96 exit (1) ;
cannam@126 97 } ;
cannam@126 98 printf ("\t SRC ratio (%9.5f) : %s ................... ok\n", ratio_test [k].ratio,
cannam@126 99 (ratio_test [k].should_pass ? "pass" : "fail")) ;
cannam@126 100 } ;
cannam@126 101
cannam@126 102 puts ("") ;
cannam@126 103
cannam@126 104 return ;
cannam@126 105 } /* src_ratio_test */
cannam@126 106
cannam@126 107 static void
cannam@126 108 error_test (void)
cannam@126 109 { const char *errorstr ;
cannam@126 110 int k, errors = 0 ;
cannam@126 111
cannam@126 112 puts (" error_test :") ;
cannam@126 113
cannam@126 114 for (k = 0 ; 1 ; k++)
cannam@126 115 { errorstr = src_strerror (k) ;
cannam@126 116 printf ("\t%-2d : %s\n", k, errorstr) ;
cannam@126 117 if (errorstr == NULL)
cannam@126 118 { errors ++ ;
cannam@126 119 continue ;
cannam@126 120 } ;
cannam@126 121 if (strstr (errorstr, "Placeholder.") == errorstr)
cannam@126 122 break ;
cannam@126 123 } ;
cannam@126 124
cannam@126 125 if (errors != 0)
cannam@126 126 { printf ("\n\nLine %d : Missing error numbers above.\n\n", __LINE__) ;
cannam@126 127 exit (1) ;
cannam@126 128 } ;
cannam@126 129
cannam@126 130 puts ("") ;
cannam@126 131
cannam@126 132 return ;
cannam@126 133 } /* error_test */
cannam@126 134
cannam@126 135 static void
cannam@126 136 zero_input_test (int converter)
cannam@126 137 { SRC_DATA data ;
cannam@126 138 SRC_STATE *state ;
cannam@126 139 float out [100] ;
cannam@126 140 int error ;
cannam@126 141
cannam@126 142 printf (" %s (%-26s) ........ ", __func__, src_get_name (converter)) ;
cannam@126 143 fflush (stdout) ;
cannam@126 144
cannam@126 145 if ((state = src_new (converter, 1, &error)) == NULL)
cannam@126 146 { printf ("\n\nLine %d : src_new failed : %s.\n\n", __LINE__, src_strerror (error)) ;
cannam@126 147 exit (1) ;
cannam@126 148 } ;
cannam@126 149
cannam@126 150 data.data_in = (float *) 0xdeadbeef ;
cannam@126 151 data.input_frames = 0 ;
cannam@126 152 data.data_out = out ;
cannam@126 153 data.output_frames = ARRAY_LEN (out) ;
cannam@126 154 data.end_of_input = 0 ;
cannam@126 155 data.src_ratio = 1.0 ;
cannam@126 156
cannam@126 157 if ((error = src_process (state, &data)))
cannam@126 158 { printf ("\n\nLine %d : src_new failed : %s.\n\n", __LINE__, src_strerror (error)) ;
cannam@126 159 exit (1) ;
cannam@126 160 } ;
cannam@126 161
cannam@126 162 state = src_delete (state) ;
cannam@126 163
cannam@126 164 puts ("ok") ;
cannam@126 165 } /* zero_input_test */